天天看點

FIND_IN_SET函數

原來以為mysql可以進行這樣的查詢

select id, list, name from table where 'daodao' IN

(list);      (一)

注:1. table含有三個字段id:int, list:varchar(255),

name:varchar(255)

實際上這樣是不行的,這樣隻有當name是list中的第一個元素時,查詢才有效,否則都的不到結果,即使'daodao'真的再list中

再來看看這個:

select

id, list, name from table where 'daodao' IN ('libk', 'zyfon', 'daodao');   

(二)

這樣是可以的

---------------------------------------------------------

這兩條到底有什麼差別呢?為什麼第一條不能取得正确的結果,而第二條卻能取得結果。

原因其實是(一)中

(list)    list是變量, 而(二)中 ('libk', 'zyfon',

'daodao')是常量

是以如果要讓(一)能正确工作,需要用find_in_set():

select id, list, name

from table where FIND_IN_SET( 'daodao' , list);

(一)的改進版。

總結:是以如果list是常量,則可以直接用IN, 否則要用FIND_IN_SET()函數

繼續閱讀