亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

SQL邏輯操作符優先性:和或

SQL邏輯操作符優先性:和或

慕斯王 2019-06-17 14:34:40
SQL邏輯操作符優先性:和或以下兩項聲明是否相等?SELECT [...]FROM [...]WHERE some_col in (1,2,3,4,5) AND some_other_expr和SELECT [...]FROM [...]WHERE some_col in (1,2,3) or some_col in (4,5) AND some_other_expr我能用什么真值表來證實這一點嗎?
查看完整描述

3 回答

?
守著星空守著你

TA貢獻1799條經驗 獲得超8個贊

And優先于Or所以即使a <=> a1 Or a2

Where a And b

Where a1 Or a2 And b,

因為這將被執行為

Where a1 Or (a2 And b)

為了使它們保持不變,您想要的是以下內容(使用括號覆蓋優先級規則):

 Where (a1 Or a2) And b

這里有一個例子來說明:

Declare @x tinyInt = 1Declare @y tinyInt = 0Declare @z tinyInt = 0Select Case When @x=1 OR @y=1 And @z=1 Then 'T' Else 'F' End -- outputs 
TSelect Case When (@x=1 OR @y=1) And @z=1 Then 'T' Else 'F' End -- outputs F

對于那些喜歡查閱參考資料的人(按字母順序排列):


查看完整回答
反對 回復 2019-06-17
?
繁花如伊

TA貢獻2012條經驗 獲得超12個贊

我再補充兩點:

  • “IN”實際上是帶有括號的串行OR。
  • 在我所知道的每一種語言中都優先于OR

所以,這兩個表達式就是不相等的。

WHERE some_col in (1,2,3,4,5) AND some_other_expr--to the optimiser is thisWHERE
     (
     some_col = 1 OR
     some_col = 2 OR 
     some_col = 3 OR 
     some_col = 4 OR 
     some_col = 5
     )
     AND
     some_other_expr

因此,當您中斷IN子句時,可以將串行OR拆分起來,并更改優先級。


查看完整回答
反對 回復 2019-06-17
?
拉風的咖菲貓

TA貢獻1995條經驗 獲得超2個贊

  1. 算術算子
  2. 級聯算子
  3. 比較條件
  4. 是[不]空,就像,[不]在
  5. [不]之間
  6. 不等于
  7. 非邏輯條件
  8. 邏輯條件
  9. 或邏輯條件

可以使用括號覆蓋優先級規則。


查看完整回答
反對 回復 2019-06-17
  • 3 回答
  • 0 關注
  • 647 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號