gpt4 book ai didi

ruby-on-rails - Rails 没有将用户数据输入到 postgresql

转载 作者:行者123 更新时间:2023-11-29 13:37:29 24 4
gpt4 key购买 nike

我遇到 Rails 没有向 postgresql 输入值的问题。数据库本身是连接的。当我运行 db:create:all(来自 database.yml 的片段)

development:
adapter: postgresql
encoding: unicode
database: website_development
username: postgres
password: *******
host: 127.0.0.1
port: 9435

(测试:相同,但数据库:website_test 而不是 website_development)所有数据库都是为测试和开发而创建的。当我运行我的 db:migration 时,也会创建用户表,例如迁移文件“date”_create_user.rb 的片段

class CreateUsers < ActiveRecord::Migration
def self.up

create_table :users do |t|
t.string :username
t.string :email

t.timestamps
end
end

def self.down
drop_table :users
end
end

(我检查了 pgAdmin 并找到了创建的表)但是当我尝试从控制台插入数据时,例如(这是在沙箱中运行的)

irb(main):001:0> User.create!(:username => "John", :email => "john@example.com)
=> #<User id: 1, username: nil, email: nil, created_at: "2011-04-26 22:00:28", u
pdated_at: "2011-04-26 22:00:28">

这是在不同的创建上生成的 sql!我已经跑了

[1m[35mSQL (2.0ms)[0m  INSERT INTO "users" ("username", "email", "created_at", "updated_at") VALUES (NULL, NULL, '2011-04-26 20:53:43.363908', '2011-04-26 20:53:43.363908') RETURNING "id"

关于为什么 rails 可以很好地创建数据库和表但找不到正确的用户名和电子邮件以输入 sql 的任何帮助。

附言我正在为我的测试运行 Rspec,并针对用户名和电子邮件的值不为 nil 进行了多项测试,所有测试均成功。

......................
Finished in 1.62 seconds
22 examples, 0 failures
Notification failed: 201 - The destination server was not reachable
Notification failed: 201 - The destination server was not reachable

如您所见,所有 Rspec 测试都是绿色的,但它无法连接到 postgres 服务器

预先感谢您的任何建议。

更新:添加了用户模型片段

class User < ActiveRecord::Base

attr_accessor :username, :email

email_regex = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i
username_regex = /\A[\w\d]+\z/i

validates :username, :presence => true,
:format => { :with => username_regex },
:length => { :maximum => 30},
:uniqueness => { :case_sensitive => false }
validates :email, :presence => true,
:format => { :with => email_regex },
:uniqueness => { :case_sensitive => false }
end

==答案==

这些是我的错误:

第 1 部分:通过将 attr_accessor 更改为 attr_accessible,我的所有测试都正常工作,所有需要变为红色的内容,这也让我可以添加 :电子邮件 详细信息但不是 :username 详细信息,这导致第 2 部分。

第 2 部分:由于某些原因,rails 不喜欢我的表被命名为 :user 而我的列被命名为 :username。所以我尝试将 :username 更改为 :loginname ,这完全解决了问题。

谢谢大家的帮助。

最佳答案

要隔离此问题,您可能需要构建一个单元测试来重现问题,然后根据需要进行修复。起初我怀疑这是 protected 属性的情况,但看起来您已经使它们可访问,这是正确的做法。

直接调用 create! 有点危险,因为在发生异常时您不容易捕捉到创建了一半的对象。这是因为尽管异常包含对模型的引用,但如果不进行额外挖掘,尚不清楚是用户模型还是其他模型首先导致了异常。

更靠谱的做法是这样的:

def test_create_example
user = User.new(:username => "John", :email => "john@example.com")

assert_equal 'John', user.username
assert_equal 'john@example.com', email

user.save

assert_equal [ ], user.errors.full_messages
assert_equal false, user.new_record?
end

如果验证流中发生错误,您将看到错误列在应该为空数组的旁边。它还通过测试记录是否不再是新记录来检查记录是否已保存,因为记录可能有效但如果 before_savebefore_create 过滤器返回 false,这是偶然发生的事情。

如果您调用 new 然后调用 save,您将有机会在保存之前和之后检查新准备的对象。

关于ruby-on-rails - Rails 没有将用户数据输入到 postgresql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5797204/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com