[精讚] [會員登入]
7417

[MySQL] FIND_IN_SET函數,把多筆條件判斷弄成字串

SQL 我們如果要查找某個欄位是否為某個值的時候,如果要判斷的條件很多,可以用這個函數

分享此文連結 //n.sfs.tw/11606

分享連結 [MySQL] FIND_IN_SET函數,把多筆條件判斷弄成字串@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2019-10-25 09:09:22 最後編修
2017-08-11 22:42:07 By 張○○
 

SQL 我們如果要查找某個欄位是否為某個值的時候,會用 WHERE 去下條件,例如:

SELECT * FROM `table` WHERE `ID`=2

當我們同時要找 `ID`=2, 5, 6, 7, ... 都可以的情況,因為數字不是連續量,用 WHERE 來寫就太醜了:

SELECT * FROM `table` WHERE `ID`=2 OR `ID`=5 OR `ID`=6 OR `ID`=7 OR ...

這時也許 ID 的值可以用 IN 取出,就是所謂的 SUBSELECT,用第2個表table2來取回所需要的ID,也許能解決大部分的問題:

SELECT * FROM `table` WHERE `ID` IN (SELECT `ID` FROM `table2` WHERE ...)

可是總是有情況不美好的時候,也就是無法用 IN 取出我要的 ID,這時如果我們已經能事先知道要查詢哪些 ID,把他用 ',' 組成一個字串,再用  FIND_IN_SET()就能解決這個問題:

SELECT * FROM `table` WHERE  FIND_IN_SET(`ID`, '2,5,6,7,8,9,11,21,33,45')

但這樣子是有缺點的:就算你把那字串的順序交換,他取回的資料還是照原本的順序取回

SELECT * FROM `table` WHERE  FIND_IN_SET(`ID`, '45,5,6,8,9,11,21,33,2,5')

這時得加上排序的方法,只是這方法稍爛,湊合湊合:

SELECT * FROM `table` WHERE  FIND_IN_SET(`ID`, '45,5,6,8,9,11,21,33,2,5') order by FIND_IN_SET(`ID`, '45,5,6,8,9,11,21,33,2,5')

SELECT * FROM `table` WHERE  FIND_IN_SET(`ID`, '45,5,6,8,9,11,21,33,2,5') order by FIELD(`ID`, 45,5,6,8,9,11,21,33,2,5)

 注意field的函式裡面要把每個資料獨立寫

參考資料

[1] https://stackoverflow.com/questions/6297369/order-by-find-in-set-and-then-and-then


編修 2010-01-09 14:21:49

END

你可能感興趣的文章

[Mysql] 建立叢集式資料庫4/4--觀察及測試 觀察及測試haproxy+galera建立Mysql的叢集式資料庫,並進行壓力測試

[Mysql] 將記錄由0變1、1變0;或是判斷後再改值的寫法 MySQL 將記錄由0變1,1變0的SQL寫法 假如欄位 `active` 為0 是失效;1 為有效,他的型態是 tin

[phpmyadmin] 登錄超時 (1440 秒未操作),請重新登錄 phpmyadmin登錄超時 (1440 秒未操作),請重新登錄的問題,該如何解決?

[Mysql/MariaDB] 表格的引擎 (engine):查看及修改 MySQL表格引擎預設為 MyISAM,但在4.0以上的mysql 其實支援不只一種引擎,各有優缺點,這篇介紹引擎的操作。

[MySQL/Mariadb] 正規表達式(regular express) mysql的正規表達式很詭異,很不能接受

[Mysql] 資料型態int, float, double, text, char, varchar, blob大小 Mysql中資料型態int, float, text, char, varchar, blob大小

隨機好文

HP SAS硬碟leds燈號說明 HP SAS硬碟leds燈號(hp g7/g6系統適用)說明

[Windows7] 移除IE10及移除IE11 Windows7 不得已的情況要移除IE11或IE10怎麼做?

[bc] linux 的計算機 bc 設定小數位數、計算π、次方根 linux 的計算機 bc 設定小數位數、計算π、次方根

詭異的創業思維 創業的思維中,有多少銀彈,有多少技術,有多少人脈,有多少時間等等,每個都要考慮進去,以熱忱建立的關係脆弱的像蘇打餅乾一樣..

設計的工作絕不接受比價 拿買陽春麵的價格想買牛肉麵,寧願倒掉也不賣