[精讚] [會員登入]
7236

[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/Mariadb] Left Join 和 Right Join 合併表單 SQL語法中的 Left Join 和 Right Join 很常用,但是我常會忘記,所以寫下來備忘。

兩次使用InnoDB的慘痛經驗 Mysql 的Innodb引擎雖然好用,但是我得說說我兩次的慘痛經驗,這讓我考慮以後可能不會再使用innodb了

[Mysql] 建立叢集式資料庫1/4 -- 安裝及設定DB1 使用galera建立Mysql的叢集式資料庫 (GALERA CLUSTER FOR MYSQL THE TRUE MULTI-MASTER)

[Mysql/Mariadb] 全文檢索 fulltext index 關於 MySQL 的全文檢索

[Mysql/MariaDB] 清除及設定 MySQL 的死連接 mysql 伺服器若有太多的連接,無疑的會耗用非常多的資源,若資源耗盡會影響新的連線,勢必要做一些調整

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

隨機好文

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

[CodeIgniter3] 解決無法上傳特定檔案(.sb2)的問題 上傳時出現The filetype you are attempting to upload is not allowed,要怎麼解決?

海棉寶寶超泡杯演奏的sweet victory 章魚哥和海棉寶寶在超泡杯的演奏歌曲

[PHP]解決ksort新增的SORT_NATURAL|SORT_FLAG_CASE方法 php>=5.4中ksort函數多了SORT_NATURAL 和 SORT_FLAG_CASE 旗標,對舊版的PHP中要怎麼辦?

[AS3] 物件加上超連結的方法 物件加上超連結,可讓使用者點擊的方法