Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How does one add an attribute to a model?

In rails I generate a model with two strings and would like to add more. How would I go about doing this?

like image 530
jsttn Avatar asked Jun 16 '11 14:06

jsttn


3 Answers

Yes, the solution by @JCorcuera is applicable, but I suggest applying a little more information to Rails to fulfill our requirement. Try this approach:

rails generate migration add_columnname_to_tablename columnname:datatype

For example:

rails generate migration add_password_to_users password:string
like image 163
vishB Avatar answered Oct 15 '22 23:10

vishB


Active Record maps your tables columns to attributes in your model, so you don't need to tell rails that you need more, what you have to do is create more columns and rails is going to detect them, the attributes will be added automatically.

You can add more columns to your table through migrations:

rails generate migration AddNewColumnToMyTable column_name:column_type(string by default)

Example:

rails generate migration AddDataToPosts views:integer clicks:integer last_reviewed_at:datetime 

this will generate a file:

db/2017.....rb

Open it and add modify it if needed:

self.up
  #add_column :tablename, :column_name, :column_type
  add_column :posts, views, :integer
  add_column :posts, clicks, :integer, default: 0
end

Hope this helps.

like image 47
JCorcuera Avatar answered Oct 15 '22 23:10

JCorcuera


If you are using the Rails 4.x you can now generate migrations with references, like this:

rails generate migration AddUserRefToProducts user:references

like you can see on rails guides

like image 2
Paulo Fidalgo Avatar answered Oct 16 '22 01:10

Paulo Fidalgo