作者热门文章
- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我的项目中有这个遗留代码:
Model.find(id, :readonly => false)
显然,它按 id 搜索并且只搜索非只读的对象。但是只读不是模型的属性,这应该检查定义该实例是否为只读实例的实际 ActiveRecord 属性。我不知道这段代码是否真的这样做了,也许 :readonly => false 在那里没用。但我收到了预期的警告:
DEPRECATION WARNING: Passing options to #find is deprecated. Please build a scope and then call #find on it.
而且我无法用 where 替换它,因为我无法检查 SQL 中的只读性,因为它不是 SQL 属性。
错误实际上明确指出,如果在范围内,我仍然可以使用查找。但我做了一个范围,就像这样:
scope :by_id_not_readonly, ->(id) { find(id, :readonly => false) }
但是同样的警告被抛出,但是在模型而不是 Controller 的范围声明行中......
我做了一些其他的测试:
用 where('id = ? AND readonly = false', id) 替换它实际上会给出一个错误,异常(exception)情况 - readonly 不是模型的正确方法。
在没有只读位的情况下运行代码会破坏测试,因为它返回只读记录并且代码稍后会尝试更新它们,从而给出错误。
向查找散列添加不正确的选项,例如find(id, :readonly => false, :ldisfs32j9fmdf90sdfds => false) 给出了一个未知的 key 错误,作为异常(exception)。
所以,这个 :readonly 位是至关重要的,但我不能用简单的 where 来代替它。我如何在较新版本的 Rails 中做到这一点?
最佳答案
试试这个:
Model.readonly(false).find(id)
它没有在什么地方使用
关于ruby-on-rails - 如何在较新的 Rails 上用只读替换查找?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23542623/
我是一名优秀的程序员,十分优秀!