4

我正在运行 Rails 3.2.8 和 ruby​​ 1.9.3p194。

我试图更好地理解究竟是如何存在的?方法在 activerecord 中起作用。我得到了一些我不明白的奇怪结果......为了清楚起见,我将在这里简化我的代码。

想象一下,我有一个包含用户列表的用户模型。

1 安迪,男
2 杰克,男
3 凯茜,女
4 迈克,男

我有男性的范围,所以:

User.male => [#< User id: 1, name: Andy, gender: male>, #< User id: 2, name: Jake, gender: male>, #< User id: 4, name: Mike, gender: male>]

好的。现在:

a = User.find 1 => #<User id: 1, name: Andy, gender: male>  
b = User.find 2 => #<User id: 2, name: Jake, gender: male> 
c = User.find 3 => #<User id: 3, name: Cathy, gender: female> 
d = User.find 4 => #<User id: 4, name: Mike, gender: male> 

User.male.exists?(a) => true  
User.male.exists?(b) => true  
User.male.exists?(c) => false  
User.male.exists?(d) => true  

好的,这是有道理的。然而:

User.male.limit(1) => [#<User id: 1, name: Andy, gender: male>]

User.male.limit(1).exists?(a) => true  
User.male.limit(1).exists?(b) => true  
User.male.limit(1).exists?(c) => false  
User.male.limit(1).exists?(d) => true  

为什么存在?(b)和存在?(d)返回true?是不是因为限制实际上并没有改变仍然是所有男性用户的查询,并且限制(1)只是一个显示的东西?我可以买这个,但是如果我只想存在,那么正确的查询是什么?(a)返回true,其他一切都返回false?

好的,现在这真的让我完全困惑:

User.male.limit(1).offset(1) => [#<User id: 2, name: Jake, gender: male>]  

User.male.limit(1).offset(1).exists?(a) => false
User.male.limit(1).offset(1).exists?(b) => false
User.male.limit(1).offset(1).exists?(c) => false
User.male.limit(1).offset(1).exists?(d) => false

为什么这里的一切都返回假?我想要存在?(b)返回真,我完全不知道为什么它不存在。如果有人能启发我,我将不胜感激。我浏览了文档无济于事。

4

1 回答 1

1

User.male添加 where 子句“性别 = 男性”

.exists?(a)添加一个额外的子句“id = 1”

limit 1limit 1只需在 where 子句之后添加一个。

所以User.male.limit(1).exists?(a)会生成 SELECT 1 FROM用户WHERE用户.id= 1 AND (gender =) LIMIT 1

所以之所以.exists?(x)起作用,是因为它将 id 添加到 where 子句中,从而选择了相关记录。

offset(1)不起作用,因为当您放置时您只会获得 1 条匹配的记录,exists?(x)并向其添加偏移量(1)意味着它应该在该记录之后查找记录。

于 2012-08-24T09:42:06.483 回答