日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

sql 为什么要用where 1=1或者where 1 =0 ?

發布時間:2023/12/20 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 sql 为什么要用where 1=1或者where 1 =0 ? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、不用where? 1=1? 在多條件查詢中的困擾

  舉個例子,如果您做查詢頁面,并且,可查詢的選項有多個,同時,還讓用戶自行選擇并輸入查詢關鍵詞,那么,按平時的查詢語句的動態構造,代碼大體如下:
?

代碼如下:

  string MySqlStr=”select * from table where”;if(Age.Text.Lenght>0){MySqlStr=MySqlStr+“Age=“+“'Age.Text'“;}if(Address.Text.Lenght>0){MySqlStr=MySqlStr+“and Address=“+“'Address.Text'“;}


  ①種假設

  如果上述的兩個IF判斷語句,均為True,即用戶都輸入了查詢詞,那么,最終的MySqlStr動態構造語句變為:
?

代碼如下:

  MySqlStr=”select * from table where Age='18'? and Address='云南省文山州廣南縣小波嗎村'”



?
  可以看得出來,這是一條完整的正確的SQL查詢語句,能夠正確的被執行,并根據數據庫是否存在記錄,返回數據。

  ②種假設

  如果上述的兩個IF判斷語句不成立,那么,最終的MySqlStr動態構造語句變為:
?

代碼如下:

  MySqlStr=”select * from table where“


  現在,我們來看一下這條語句,由于where關鍵詞后面需要使用條件,但是這條語句根本就不存在條件,所以,該語句就是一條錯誤的語句,肯定不能被執行,不僅報錯,同時還不會查詢到任何數據。

  上述的兩種假設,代表了現實的應用,說明,語句的構造存在問題,不足以應付靈活多變的查詢條件。

  二、使用 where? 1=1? 的好處

?

  假如我們將上述的語句改為:
?

代碼如下:

  string MySqlStr=”select * from table where? 1=1 ”;if(Age.Text.Lenght>0){MySqlStr=MySqlStr+“and Age=“+“'Age.Text'“;}if(Address.Text.Lenght>0){MySqlStr=MySqlStr+“and Address=“+“'Address.Text'“;}


  現在,也存在兩種假設

  ①種假設

  如果兩個IF都成立,那么,語句變為:
?

代碼如下:

  MySqlStr=”select * from table where? 1=1 and Age='18'? and Address='云南省文山州廣南縣小波嗎村'”,很明顯,該語句是一條正確的語句,能夠正確執行,如果數據庫有記錄,肯定會被查詢到。



?
  ②種假設

  如果兩個IF都不成立,那么,語句變為:

  MySqlStr=”select * from table where 1=1”,現在,我們來看這條語句,由于where 1=1 是為True的語句,因此,該條語句語法正確,能夠被正確執行,它的作用相當于:

?

MySqlStr=”select * from table”,即返回表中所有數據。

  言下之意就是:如果用戶在多條件查詢頁面中,不選擇任何字段、不輸入任何關鍵詞,那么,必將返回表中所有數據;如果用戶在頁面中,選擇了部分字段并且輸入了部分查詢關鍵詞,那么,就按用戶設置的條件進行查詢。

  說到這里,不知道您是否已明白,其實,where 1=1的應用,不是什么高級的應用,也不是所謂的智能化的構造,僅僅只是為了滿足多條件查詢頁面中不確定的各種因素而采用的一種構造一條正確能運行的動態SQL語句的一種方法。

where 1=0; 這個條件始終為false,結果不會返回任何數據,只有表結構,可用于快速建表
?

代碼如下:

"SELECT * FROM strName WHERE 1 = 0";


該select語句主要用于讀取表的結構而不考慮表中的數據,這樣節省了內存,因為可以不用保存結果集。?

代碼如下:

create table newtable as select * from oldtable where 1=0;? 創建一個新表,而新表的結構與查詢的表的結構是一樣的。

?

總結

以上是生活随笔為你收集整理的sql 为什么要用where 1=1或者where 1 =0 ?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。