1

私の Michael HartlのLearn Ruby on Rails チュートリアルに従おうとしています。データベースからユーザーデータを取得してページを表示する第7章にいます。ただし、IDが1のユーザーがいないというエラーが発生し続けます。データベース内のデータを確認できません (SQL データベース ビューアーでファイルを開くことができないと表示され、その問題を修正したとされる 1.1 バージョンをインストールする方法がわかりません)。

コンソールにユーザーを追加しようとしましたが、成功したようですが、作成したばかりのユーザーを見つけようとすると、存在しません (以下を参照)。何か助けはありますか?私は今とてもイライラしています。

User.find

1.9.3-p327 :001 > User.find(1)
  User Load (31.4ms)  SELECT "users".* FROM "users" WHERE "users"."id" = $1 LIMIT 1  [["id", 1]]
ActiveRecord::RecordNotFound: Couldn't find User with id=1
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/activerecord-3.2.9/lib/active_record/relation/finder_methods.rb:341:in `find_one'
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/activerecord-3.2.9/lib/active_record/relation/finder_methods.rb:312:in `find_with_ids'
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/activerecord-3.2.9/lib/active_record/relation/finder_methods.rb:107:in `find'
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/activerecord-3.2.9/lib/active_record/querying.rb:5:in `find'
    from (irb):1
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/railties-3.2.9/lib/rails/commands/console.rb:47:in `start'
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/railties-3.2.9/lib/rails/commands/console.rb:8:in `start'
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/railties-3.2.9/lib/rails/commands.rb:41:in `<top (required)>'
    from script/rails:6:in `require'
    from script/rails:6:in `<main>'

ユーザー.作成

1.9.3-p327 :002 > User.create(name: "MD", email: "md@example.com", password: "foobar", password_confirmation: "foobar")
   (22.6ms)  SAVEPOINT active_record_1
  User Exists (56.7ms)  SELECT 1 AS one FROM "users" WHERE LOWER("users"."email") = LOWER('md@example.com') LIMIT 1
  SQL (153.7ms)  INSERT INTO "users" ("created_at", "email", "name", "password_digest", "updated_at") VALUES ($1, $2, $3, $4, $5) RETURNING "id"  [["created_at", Mon, 11 Feb 2013 00:59:52 UTC +00:00], ["email", "md@example.com"], ["name", "MD"], ["password_digest", "$2a$10$NFEb9PsPQuSEGbJ8.TOILefjZMgTAJXCFHExZpGZmlov72UffjoUe"], ["updated_at", Mon, 11 Feb 2013 00:59:52 UTC +00:00]]
   (0.4ms)  RELEASE SAVEPOINT active_record_1
 => #<User id: 4, name: "MD", email: "md@example.com", created_at: "2013-02-11 00:59:52", updated_at: "2013-02-11 00:59:52", password_digest: "$2a$10$NFEb9PsPQuSEGbJ8.TOILefjZMgTAJXCFHExZpGZmlov..."> 

User.find

1.9.3-p327 :003 > User.find(1)
  User Load (2.2ms)  SELECT "users".* FROM "users" WHERE "users"."id" = $1 LIMIT 1  [["id", 1]]
ActiveRecord::RecordNotFound: Couldn't find User with id=1
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/activerecord-3.2.9/lib/active_record/relation/finder_methods.rb:341:in `find_one'
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/activerecord-3.2.9/lib/active_record/relation/finder_methods.rb:312:in `find_with_ids'
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/activerecord-3.2.9/lib/active_record/relation/finder_methods.rb:107:in `find'
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/activerecord-3.2.9/lib/active_record/querying.rb:5:in `find'
    from (irb):3
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/railties-3.2.9/lib/rails/commands/console.rb:47:in `start'
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/railties-3.2.9/lib/rails/commands/console.rb:8:in `start'
    from /home/gerard/.rvm/gems/ruby-1.9.3-p327/gems/railties-3.2.9/lib/rails/commands.rb:41:in `<top (required)>'
    from script/rails:6:in `require'
    from script/rails:6:in `<main>'
4

3 に答える 3

1

@aceofbassgreg が述べたように、実行した User.create メソッドにより、ID 4 のユーザーが作成されました。

チュートリアル中に、いくつかのユーザー インスタンスを作成および削除した可能性があります。新しいユーザーを作成するたびに、ID フィールドの値が自動的に生成され、増加し続けます。これは主キーでもあります。

ID 列には auto_increment 属性があります。これは RDBMS によって自動的に決定され、オブジェクトの新しいインスタンスが作成されるたびに 1 ずつ増加します。したがって、3 つのユーザー オブジェクトを作成してから削除すると、テーブルが空であっても、次のユーザー オブジェクトの ID は 4 になります。もちろん、適切な SQL コマンドを使用して auto_increment カウンターを任意の値にリセットできます。

その上、セキュリティ上の理由から、create メソッドは主キー (このキーの ID) と継承フィールドをパラメーターとして渡す (「一括割り当て」) ときにそれらを無視します。そのため、 User.create(:id => 1) は機能しません。

于 2013-02-12T04:23:07.217 に答える
1

Railsコンソールを使用していると仮定しますが、

その場合、ユーザーをデータベースに追加したら、コンソールをリロードする必要があります

あなたのレールコンソールで

User.create(name: "MD", email: "md@example.com", password: "foobar", password_confirmation: "foobar")

reload!

User.find(1)
于 2013-02-11T03:50:34.283 に答える
1

コマンドラインで「rake db:migrate」を実行済みで、db フォルダーに sqlite3 データベース ファイルが既に生成されていると思います。

于 2013-02-11T01:22:18.200 に答える