| 我遇到了这个难题 
 in the comments here CREATE TABLE r (b INT);
SELECT 1 FROM r HAVING 1=1; SQL Server和PostgreSQL返回1行. MySQL和Oracle返回零行. 哪个是对的?或两者同样有效? 解决方法按标准:SELECT 1 FROM r HAVING 1=1 手段 SELECT 1 FROM r GROUP BY () HAVING 1=1 引用ISO / IEC 9075-2:2011 7.10语法规则1(HAVING子句定义的一部分):  
  Let HCbe the<having clause>. LetTEbe the<table expression>thatimmediately contains
 HC. IfTEdoes not immediately contain a
 <group by clause>,then “GROUP BY ()” is implicit. LetTbe thedescriptor of the table defined by the
 <group by clause>GBCimmediatelycontained in
 TEand letRbe the result ofGBC. 好的,非常清楚. 断言:1 = 1是真正的搜索条件.我不会为此提供任何引用. 现在 SELECT 1 FROM r GROUP BY () HAVING 1=1 是等于 SELECT 1 FROM r GROUP BY () 引用ISO / IEC 9075-2:2011 7.10一般规则1:  
  The <search condition>is evaluated for each groupof
 R. The result of the<having clause>is a groupedtable of those groups of R for which the result of the
 
 <search condition>is True. 逻辑:由于搜索条件始终为真,因此结果为R,这是group by expression的结果. 以下摘录自7.9的一般规则(GROUP BY CLAUSE的定义)  
  1) If no <where clause>is specified,then letTbe the result of the preceding<from clause>; otherwise,letTbe the result of the preceding<where clause>. 2) Case: a) If there are no grouping columns,then the result ofthe
 <group by clause>is the grouped table consisting ofTas its only group. 因此,我们可以得出结论 FROM r GROUP BY () 得到一个分组表,由一个组组成,零行(因为R为空). 7.12的一般规则的摘录,它定义了一个查询规范(a.k.a一个SELECT语句):  
  1) Case: a) If Tis not a grouped table,then […] b) If Tis a grouped table,then Case: i) If Thas 0 (zero) groups,then let TEMP be an empty table. ii) If Thas one or more groups,then each<value expression>is appliedto each group of
 Tyielding a tableTEMPofMrows,whereMis thenumber of groups in
 T. Thei-th column of TEMP contains the valuesderived by the evaluation of the
 i-th<value expression>. […] 2) Case: a) If the <set quantifier>DISTINCTis not specified,then theresult of the
 <query specification>isTEMP. 因此,由于表有一个组,因此它必须有一个结果行. 从而 SELECT 1 FROM r HAVING 1=1 应返回1行结果集. 证明完毕 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |