добавление внешнего ключа в таблицу

#ruby-on-rails #ruby-on-rails-3 #foreign-keys #foreigner

#ruby-на-рельсах #ruby-on-rails-3 #внешние ключи #иностранец

Вопрос:

Я продолжаю получать это исключение: "SQLite3::SQLException: no such column: books.user_id: SELECT "books".* FROM "books" WHERE ("books".user_id = 4)" . Похоже, что в таблице books нет идентификатора пользователя.

Итак, я просто установил плагин Foreigner и добавил "t.integer :user_id, :null => false" и "add_foreign_key(:books, :users)" в файл миграции книги. Я запустил "rake db:migrate" , но все равно выдает мне то же исключение.

Я использую Rails 3 в Windows и Devise для аутентификации пользователя.

ДОМАШНИЙ ПРОСМОТР

   <p><%= link_to "Add new Book",:controller =>"book", :action => 'new' %></p>
   <% @books.each do |b| %>
  <p><%= b.author%></p>
  <p><%= b.title%></p>
  <%end%>
  

ДОМАШНИЙ КОНТРОЛЛЕР

    class HomeController < ApplicationController
   def index
  @user = current_user
  @user.books||=Book.new
  @books=@user.books
  end
  end
  

BOOK КОНТРОЛЛЕР

     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
  

МИГРАЦИЯ СОЗДАНИЯ ТАБЛИЦЫ / КНИГИ

   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
  

ПРОСМОТР КНИГИ

 <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"%> 
  

КНИЖНАЯ МОДЕЛЬ

  class Book < ActiveRecord::Base
 belongs_to :user
 end
  

ПОЛЬЗОВАТЕЛЬСКАЯ МОДЕЛЬ

 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
  

МАРШРУТ
Campus::Application.routes.нарисовать сделать
получаем «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
  

СХЕМА БАЗЫ ДАННЫХ

     ActiveRecord::Schema.define(:version => 20110609055608) do

  create_table "books", :force => true do |t|
    t.text     "title"
    t.text     "author"
    t.integer  "user_id",    :null => false
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  create_table "courses", :force => true do |t|
    t.string   "name"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  create_table "strong_ins", :force => true do |t|
    t.string   "subject"
    t.string   "topic"
    t.text     "description"
    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

  create_table "weak_ins", :force => true do |t|
    t.string   "subject"
    t.string   "topic"
    t.text     "description"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

end
  

Ответ №1:

user_id Столбец должен появиться в схеме после запуска миграции. Этого нет в вашем списке, поэтому я бы сказал, что это проблема. Убедитесь, что rake db:migrate все завершается без ошибок. При необходимости вы можете повторить миграцию с помощью rake db:rollback amp;amp; rake db:migrate .

Комментарии:

1. я только что запустил rake db: rollback, а затем снова rake db: migrate, все еще выдавая мне то же исключение

2. Можете ли вы проверить log/development.log и посмотреть, регистрируется ли инструкция SQL?

3. Если подумать, foreigner это может не сработать с SQLite. Попробуйте удалить add_foreign_key инструкцию и снова запустить миграцию.

4. хорошо, я смог добавить внешний ключ, но книга не отображается в представлении Home / index. Эта информация содержится в файле dev.log Загрузка (3.0мс)[0m ВЫБЕРИТЕ «пользователи».* ИЗ «users», ГДЕ «users».»id» = 4 ОГРАНИЧИТЬ загрузку 1 [1m[36mBook (1.0ms)[0m [1mвыберите «книги».* ИЗ «books», ГДЕ («books».user_id = 4)[0m