I keep getting this exception "SQLite3::SQLException: no such column: books.user_id: SELECT "books".* FROM "books" WHERE ("books".user_id = 4)" ,which sounds like there is no user_id in books table.So i just installed foreigner plugin and added " t.integer :user_id, :null => false" and "add_foreign_key(:books, :users)" in book migration and i ran "rake db:migrate" but still it is giving me the same exception.I am using Rails 3 in windows and devise to authenticate user. HOME VIEW <p><%= link_to "Add new Book",:controller =>"book", :action => 'new' %></p> <% @books.each do |b| %> <p><%= b.author%></p> <p><%= b.title%></p> <%end%> HOME CONTROLLER
class HomeController < ApplicationController def index @user = current_user @user.books||=Book.new @books=@user.books end end BOOK CONTROLLER class BookController < ApplicationController def new @books = Book.new # redirect_to :controller=>"home" ,:action=>"index" end def create @books = Book.new(params[:book]) if @books.save render "home/index" #redirect_to :controller=>"home" ,:action=>"index" else render :action => 'new' end end CREATE TABLE/BOOK MIGRATION class CreateBooks < ActiveRecord::Migration def self.up create_table :books do |t| t.text :title t.text :author t.integer :user_id, :null => false t.timestamps end add_foreign_key(:books, :users) end BOOK VIEW <h1>Book#new</h1> <%= form_for(:book) do |f| %> <p><%= f.text_field :title %></p> <p><%= f.text_field :author %></p> <p><%= f.submit "Add book"%> BOOK MODEL class Book < ActiveRecord::Base belongs_to :user end USER MODEL class User < ActiveRecord::Base has_many :books # Include default devise modules. Others available are: # :token_authenticatable, :lockable, :timeoutable and :activatable devise :database_authenticatable, :registerable, :recoverable, :rememberable, :trackable, :validatable # Setup accessible (or protected) attributes for your model attr_accessible :email, :password, :password_confirmation,:firstname,:lastname,:school,:major,:sex,:zipcode end ROUTE Campus::Application.routes.draw do get "book/index" get "book/edit" get "book/new" get "home/edit" devise_for :users resources :book root :to=> "home#index" match '/book/new' =>"home#index" end DATABASE SCHEMA ActiveRecord::Schema.define(:version => 20110609055608) do create_table "books", :force => true do |t| t.text "title" t.text "author" t.datetime "created_at" t.datetime "updated_at" end create_table "users", :force => true do |t| t.string "email", :default => "", :null => false t.string "encrypted_password", :limit => 128, :default => "", :null => false t.string "password_salt", :default => "", :null => false t.string "reset_password_token" t.string "remember_token" t.datetime "remember_created_at" t.integer "sign_in_count", :default => 0 t.datetime "current_sign_in_at" t.datetime "last_sign_in_at" t.string "current_sign_in_ip" t.string "last_sign_in_ip" t.datetime "created_at" t.datetime "updated_at" t.string "firstname" t.string "lastname" t.text "school" t.text "major" t.string "sex" t.integer "zipcode" end add_index "users", ["email"], :name => "index_users_on_email", :unique => true add_index "users", ["reset_password_token"], :name => "index_users_on_reset_password_token", :unique => true end -- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group. To post to this group, send email to rubyonrails-talk@googlegroups.com. To unsubscribe from this group, send email to rubyonrails-talk+unsubscr...@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en.