欧美日韩1234-岳两女共夫互换观看视频-日本不卡一区二区-gogogo高清国语完整-国产区在线-狠久久-男男互操视频-另类国产-欧美人与禽猛交乱配视频-欧美另类一区-久久成人在线视频-国产一级片av-青青草视频播放-欧美三级黄-日日射天天射-在线国产欧美-日韩永久-国产黄色成人-伊人三区-国产午夜精品理论片-999精彩视频-免费看av软件-欧美xxxx喷水-国产蜜臀-美女四肢被绑在床扒衣-日本公妇乱淫-99久久久国产精品无码性

027-81331413

mysql中FIND_IN_SET()用法以及與in()的區別

發布時間:2013-08-09 瀏覽:7791

mysql中如何使用FIND_IN_SET(),以及使用FIND_IN_SET()注意的地方,還有F第二世界整理發布IND_IN_SET()與in()的使用區別。

在mysql中查詢表字段 pingid = (1,2,3,)

SELECT * FROM `linkinfo` WHERE `pingid` REGEXP '{id},' AND `pingid` NOT REGEXP '[[:alnum:]]+{id},' 使用上面的語句,可以查詢出來

用FIND_IN_SET() 更簡單

SELECT * FROM linkinfo WHERE FIND_IN_SET( '1', pingid )

原來以為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()函數.