sql語句not and or執行順序

2021-08-27 07:30:28 字數 594 閱讀 7512

今天的**中很悲催的出現了資訊洩漏的情況,開始我怎麼都不肯相信,首先自信自己的程式設計技術,其次自信自己對業務邏輯的理解,最後徹查**的時候,卻發現問題出現在sql語句的邏輯判斷上,這裡記錄一下吧

首先,sql語句中邏輯運算子優先順序跟c一樣,not > and > or (c裡面是 ! > && > || )

select * from table_name where a = 1 and b = 2 or c =  3;

我的本意:

在table_name表裡選擇a = 1 並且 (b = 2 或者 c = 3)的結果集,但是結果肯定不和我想的一樣,結果集是 (a = 1 並且 b =2 ) 的結果集或者 c = 3的結果集

因為sql的執行順序為:

select * from table_name where (a = 1 and b = 2) or c = 3;

如果想達到我想的效果:

select * from table_name where a = 1 and (b = 2 or c = 3);

執行sql語句 檢視SQL語句執行進度資訊

有時候我們跑乙個語句,若修改大表或查詢量很大時候,不知道執行到什麼程度了,什麼時候能執行完成,在5.7版後可以查詢sys.session來觀察 select from sys.session where conn id connection id 模擬對乙個大表執行了alter操作 alter ta...

AIR執行SQL語句

我們的sql語句的執行都是由乙個類來完成的!這個類就是sqlstatement 這個類就是我們用來執行sql語句的類,該類的使用也是非常簡單的,我們只需要記住兩個屬性兩個方法。我們來看一下!text屬性 所要執行的sql語句,該屬性是乙個字串格式,所以我們的sql語句都是字串!sqlconnecti...

sql語句執行效率

兩種執行的效果一樣,但執行的速度不一樣,在大資料的時候,可看出。select distinct a.o flowid from chengjiinfo as a where k kecheng not in select kemu from chengjidankeinfo where o flow...