3

在沙盒模式下通过 Heroku 控制台运行开发代码时,我使用 first_or_create 测试记录是否存在:

Right.where(:language           => language          ).
      where(:work_id            => work_id           ).
      where(:contact_id         => contact_id        ).
      first_or_create!

用于测试记录是否存在的查询会添加一个额外的谓词 (1=2),因此找不到该记录。

SELECT "rights".* FROM "rights" WHERE "rights"."language" = 'ger' AND "rights"."work_id" = 625 AND "rights"."contact_id" = 1435 AND (1 = 2) LIMIT 1

任何人都可以建议我如何追踪它的来源 - 也许是沙盒模式的事情?

编辑:沙盒模式被调用:

heroku run console -s --app my-app-name

在 Heroku 上以沙盒模式运行 Rails 控制台

4

1 回答 1

2

好的,谜团解开了。

first_or_create 是从一个方法调用的,该方法为许多属性传递了参数。就像是:

def get_right(language,work_id,contact_id,terms)
  right = Right.where(:language           => language          ).
                where(:work_id            => work_id           ).
                where(:terms              => terms             ).
                where(:contact_id         => contact_id        ).
                first_or_create!
  right.id
end

当方法被调用时,terms 参数被作为 {} 而不是 nil 传递。

显然,activerecord 处理这种愚蠢的方法是删除查询中违规列(术语)上的谓词,并改为附加一个 (1 = 2) 谓词。

我不能说我宁愿遇到错误:(

于 2013-06-05T13:35:56.820 回答