任何人都可以解释以下两个请求之间的差异:
SET @foundnow=0;
SELECT id, (@foundnow:=IF(`id`=3,1,0)) as ff
FROM `sometable`
HAVING @foundnow=0
result is
id ff
1 0
2 0
3 1
和
SET @foundnow=0;
SELECT id, (@foundnow:=IF(`id`=3,1,0)) as ff
FROM `sometable`
HAVING ff=0
result is
id ff
1 0
2 0
4 0
5 0
...
为什么首先给出所有行的id = 3(包括),第二行 - 所有行除了id = 3?
我猜这个问题与以下请求的“意外”行为相关
SET @tot=0;
SELECT @tot:=@tot+1 as `ff`
FROM `anytable`
HAVING (`ff`>10)
给出了ff = 12,14,16,18 ......
的行答案 0 :(得分:1)
@foundnow
不是每行变量。它依然存在。创建列ff
使其成为每行值。另外,来自the documentation:
在SELECT语句中,仅在发送到客户端时评估每个select表达式。这意味着在HAVING,GROUP BY或ORDER BY子句中,引用一个在select表达式列表中赋值的变量不能按预期工作:
这意味着您的第一个示例如下:
你的第二个就像:
因此,如果@foundrow!= 0,第一个示例不会评估表达式 ,因为@foundrow已知并且MySQL不关心该select表达式中的内容。第二个引用结果集中的一列,因此必须知道该结果,并执行select。
另外,如果可以使用HAVING
,请避免使用WHERE
条款。非常非常喜欢