[精讚] [會員登入]
7284

[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] 資料型態int, float, double, text, char, varchar, blob大小 Mysql中資料型態int, float, text, char, varchar, blob大小

[Mysql/Mariadb] Left Join 和 Right Join 合併表單 SQL語法中的 Left Join 和 Right Join 很常用,但是我常會忘記,所以寫下來備忘。

[Mysql/Mariadb] GROUP_CONCAT 函數 MySQL 中和 group by 一起用的函式,如果我們要算數值的總和或平均,可以使用 sum() 或 avg() 。但是我們如果要在 group by 中把字串「黏起來」,不是使用 concat(

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

[Mysql/Mariadb] 利用phpMyAdmin 建立關聯式資料表 利用phpMyAdmin 建立關聯式資料表

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

隨機好文

[MAC] 截取螢幕畫面的方法 截取螢幕畫面的方法,在MAC中叫作螢幕快照,英文是screenshot

[jQuery] select 元件的取值及給值 html中的元件select,在jquery中要如何使用?

[Freebsd] 定時測試 ADSL 是否斷線並重連 中華電信 ADSL 雖有固定 ip,可是他卻會不定時「斷線」, 使用以下的 方法可以定時測試是否斷線,以及重新撥接。

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

「許功蓋」的字以及源由 有玩過電腦一段時間的人,都聽過這個人(有一天我才發現7年級的竟然都不認識這個