Okay, so you have got the basic set up of your application, we need to create a basic database with users and a way for users to add content under posts. In order to do that you will have to create a migration.
First, let's start with running rake -T
and see all the options we have available to us.
rake console # Starts console rake db:create # Creates the database from DATABASE_URL or config/database.yml for the current RAILS_ENV (... rake db:create_migration # Create a migration (parameters: NAME, VERSION) rake db:drop # Drops the database from DATABASE_URL or config/database.yml for the current RAILS_ENV (us... rake db:environment:set # Set the environment value for the database rake db:fixtures:load # Loads fixtures into the current environment's database rake db:migrate # Migrate the database (options: VERSION=x, VERBOSE=false, SCOPE=blog) rake db:migrate:status # Display status of migrations rake db:prepare # Runs setup if database does not exist, or runs migrations if it does rake db:rollback # Rolls the schema back to the previous version (specify steps w/ STEP=n) rake db:schema:cache:clear # Clears a db/schema_cache.yml file rake db:schema:cache:dump # Creates a db/schema_cache.yml file rake db:schema:dump # Creates a db/schema.rb file that is portable against any DB supported by Active Record rake db:schema:load # Loads a schema.rb file into the database rake db:seed # Loads the seed data from db/seeds.rb rake db:seed:replant # Truncates tables of each database for current environment and loads the seeds rake db:setup # Creates the database, loads the schema, and initializes with the seed data (use db:reset ... rake db:structure:dump # Dumps the database structure to db/structure.sql rake db:structure:load # Recreates the databases from the structure.sql file rake db:version # Retrieves the current schema version number
As you can see if we run rake db:create_migration
with the correct parameters it will create a migration
So, lets create a users and posts migration by running the following code.
rake db:create_migration NAME=create_users
and rake db:create_migration NAME=create_posts
You will discover that this will create two files in your db/migrate directory. We will need to add the following code into the Users table.
class CreateUsers < ActiveRecord::Migration[6.0] def change create_table :users do |t| t.string :username end end end
Next, we will need to add the following code into the Posrs table.
class CreatePosts < ActiveRecord::Migration[6.0] def change create_table :posts do |t| t.string :title t.text :content t.integer :user_id end end end
You will also need to create two new files in models, one named user.rb and one named post.rb, which will inherit ActiveRecord::Base.
class Post < ActiveRecord::Base belongs_to :user end
class User < ActiveRecord::Base has_many :posts end
Lastly we will need to migrate these two tables by running, rake db:migrate
If you run into errors while running rake db:migrate
please check you ActiveRecord::Migration version
If everything ran correctly, you should now be able to run rake console
or type tux
you will be able to modify your database including creating users and posts.
u = User.create(username: username= "John")
creates a user
p = Post.create(title: title= "first title", content: content="this is content")
creates a user
p.user = u
sets the user_id in post equal to the 'u' user
p
Should return the following:
=> #<Post:0x00007f8358b5eea0 id: 1, title: "first title", content: "this is content", user_id: 1>
Great! Now your database is all setup :) Play around in the rake console
and tux
to build up your database.
Top comments (0)