mysql id in set_mysql数据库中find_in_set()和in()用法区别
mysql數(shù)據(jù)庫中find_in_set()和in()用法區(qū)別
(2015-07-19 08:30:21)
標(biāo)簽:
mysql數(shù)據(jù)庫
find_in_set
在mysql中in可以包括指定的數(shù)字,而find_in_set()用于特定的數(shù)據(jù)類型,下面我來給大家介紹關(guān)于find_in_set()和in()用法區(qū)別,希望對大家所有幫助。
mysql中如何使用FIND_IN_SET(),以及使用FIND_IN_SET()注意的地方,還有F第二世界整理發(fā)布IND_IN_SET()與in()的使用區(qū)別。
在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可以進(jìn)行這樣的查詢
select id, list, name from table where 'daodao' IN (list);
(一)
注:1. table含有三個(gè)字段id:int, list:varchar(255), name:varchar(255)
實(shí)際上這樣是不行的,這樣只有當(dāng)name是list中的第一個(gè)元素時(shí),查詢才有效,否則都的不到結(jié)果,即使'daodao'真的再list中
再來看看這個(gè):
select id, list, name from table where 'daodao' IN ('libk',
'zyfon', 'daodao'); (二)
這樣是可以的
---------------------------------------------------------
這兩條到底有什么區(qū)別呢?為什么第一條不能取得正確的結(jié)果,而第二條卻能取得結(jié)果。
原因其實(shí)是(一)中 (list) list是變量, 而(二)中 ('libk', 'zyfon',
'daodao')是常量
所以如果要讓(一)能正確工作,需要用find_in_set():
select id, list, name from table where FIND_IN_SET( 'daodao' ,
list); (一)的改進(jìn)版。
總結(jié):所以如果list是常量,則可以直接用IN, 否則要用FIND_IN_SET()函數(shù).
分享:
喜歡
0
贈金筆
加載中,請稍候......
評論加載中,請稍候...
發(fā)評論
登錄名: 密碼: 找回密碼 注冊記住登錄狀態(tài)
昵???稱:
評論并轉(zhuǎn)載此博文
發(fā)評論
以上網(wǎng)友發(fā)言只代表其個(gè)人觀點(diǎn),不代表新浪網(wǎng)的觀點(diǎn)或立場。
總結(jié)
以上是生活随笔為你收集整理的mysql id in set_mysql数据库中find_in_set()和in()用法区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: gps数据存储mysql_gps数据存储
- 下一篇: linux cmake编译源码,linu