草庐IT

数据属性

全部标签

ruby - 哪个查询去了哪个数据库的 ActiveRecord 日志

在与不同数据库有多个连接的ActiveRecord应用程序中,日志中没有任何内容表明哪个查询去了哪个数据库。这些查询分离数据库:Base1.connection.select_value("select*fromfoo")Base2.connection.select_value("select*fromfoo")发出这些日志条目:D,[2017-03-13T09:27:11.844395#22112]DEBUG--:(0.6ms)select*fromfooD,[2017-03-13T09:27:11.844539#22112]DEBUG--:(0.1ms)select*fromfo

ruby-on-rails - 为 Rails 迁移加载种子数据

我有一个现有的数据库,我正在将以前的“NULL”列转换为具有默认值的列(并使用所述默认值填充该列)。但是,该值是我需要创建的记录的ID。如果我将此记录放入db/seeds.rb,它不会运行,因为db/seeds.rb在迁移之后运行——但迁移需要种子数据。如果我在迁移中保留记录创建,那么如果我使用db:load创建新数据库,我将不会获得记录。除了在db/seeds.rb和迁移中复制它之外,还有更好的方法吗?谢谢! 最佳答案 虽然我能理解您希望保持DRY并且不必在migration和seeds.rb中都写这个,但我认为您应该在两个地方都

ruby-on-rails - 多个数据库的测试和 database_cleaner

我们有一个邮箱模型,它使用另一个邮件应用程序也连接到的辅助数据库。这称为使用establish_connection:mail_database现在,我想我可以尝试将它包装在if语句中,以便它为测试环境使用不同的连接,但我想知道如何保持这个数据库的清洁,最好使用我们已经将其用于“常规”数据库的database_cleaner。我希望有人能将我推向正确的方向。 最佳答案 我有一个使用rspec(2.12.0)和使用database_cleaner(0.9.1f4b44bb)测试的rails3.2.10应用程序,它有两个用于mysql的

ruby-on-rails - Rails 5.2 Active Storage 添加自定义属性

我有一个带有附件的模型:classProject当我附加并保存图像时,我还想保存附加的自定义属性-display_order(整数)和附加图像。我想用它来对附加的图像进行排序,并按照我在此自定义属性中指定的顺序显示它们。我已经查看了#attach方法以及ActiveStorage::Blob模型的ActiveStorage源代码,但看起来没有内置方法来传递一些自定义元数据。我想知道,用ActiveStorage解决这个问题的惯用方法是什么?在过去,我通常只是将display_order属性添加到代表我的附件的ActiveRecord模型,然后简单地将它与.order(display_o

ruby-on-rails - 没有数据库的注册或邀请电子邮件验证

我想让我的数据库中几乎没有陈旧的帐户,我正在考虑进行新的注册和邀请,将他们的数据作为加密或散列url放入欢迎电子邮件中。一旦访问url中的链接,信息就会作为帐户添加到数据库中。目前有什么东西可以做到这一点吗?关于以这种方式进行用户注册的任何引用、想法或警告?谢谢!编辑:我做了一个工作示例,url是127个字符。http://localhost/confirm?_=hBRCGVqie5PetQhjiagq9F6kmi7luVxpcpEYMWaxrtSHIPA3rF0Hufy6EgiH%0A%2BL3t9dcgV9es9Zywkl4F1lcMyA%3D%3D%0A显然,更多数据=更大的ur

ruby - 使用 YARD 记录模型属性

我正在使用YARD使用makrdown作为脚本解析器为我的Rails应用程序生成文档。大多数文档功能开箱即用。但是,我还想将模型属性记录为一个,记录模型上的可用属性列表和两个,以描述它们的语义。我无法在YARD中找到对此的任何特殊支持,我基本上只能在类注释中简单地列出属性。有没有办法记录动态生成的模型属性,以便它们像标准属性/方法一样出现在文档中?附言我已经使用annodate-modelsgem在类列表的顶部生成基本模式转储,但这并不是我真正想要的。 最佳答案 似乎YARD现在有自己的@!attribute(注意感叹号)标签用于此

ruby-on-rails - ActiveRecord 与两个数据库对话?

我们最近改进了一个项目,希望将我们所有的旧数据带入新系统。问题在于架构略有不同,因此无法直接导入SQL。由于一些非规范化和数据库更改,我们需要在数据准备好导入之前对数据进行一些处理。我希望是这样的:OldUser.all.eachdo|ou|NewUser.create({:first_name=>ou.first_name:last_name=>ou.last_name:login=>ou.login:company_name=>ou.company.name})end在上面的示例中,OldUser正在从旧数据库读取数据,而NewUser正在处理新数据库。我需要两组模型(新的和旧的)

ruby-on-rails - Heroku 上的数据库连接

哇,我已经被困在这个问题上好几天了。我无法连接到Heroku上的database.yml。我在使用Cedar和ruby​​1.9.2。我的开发和测试数据库是sqlite3,生产数据库是postgreSQL以应对Cedar规则。这是我的ruby​​脚本中的代码:Rails.env.production??(env="production"):(env="development")dbconfig=YAML::load(File.open('config/database.yml'))[env]ActiveRecord::Base.establish_connection(dbconfig

ruby-on-rails - 在 Rails 中保存后向属性添加了奇怪的字节

我们遇到了一个疯狂的错误,在保存电子邮件时,大约90%的时间看似随机的字节被附加到电子邮件字段。以下是可能发生的情况的示例:Fromparams:'user@example.com'Beforevalidate:'user@example.com'Aftervalidate:'user@example.com'Beforesave:'user@example.com'Valueinobjectaftersave:'user@example.com'Retrieverecordjustcreatedbyid,andfetchid:'user@example.com\u007f'Where

ruby - 在没有 ActiveRecord 的情况下为属性设置默认值的最佳方法?

我认为这个问题(Howtodoattr_accessor_with_defaultinruby?)回答了我的问题,但我没有使用ActiveRecord和after_initialize取决于它。为attr_accessor实现默认值的Ruby最佳实践是什么?是this最接近文档的东西是什么?我应该停止使用attr_accessor因为它是私有(private)的吗? 最佳答案 classFoo#class-levelinstancevariable#settinginitialvalue(optional)@class_var=42