程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> mysql的FIND_IN_SET()用法

mysql的FIND_IN_SET()用法

編輯:MySQL綜合教程

mysql的FIND_IN_SET()用法   FIND_IN_SET(str,strlist) 返回str在字符串集strlist中的序號(任何參數是NULL則返回NULL,如果str沒找到返回0,參數1包含","時工作異常) 例子: 查詢表字段 pingid = (1,2,3,)   SELECT * FROM `linkinfo` WHERE `pingid` REGEXP '{id},' AND `pingid` NOT REGEXP '[[:alnum:]]+{id},'   使用上面的語句,可以查詢出來   用FIND_IN_SET() 更簡單   SELECT*FROMlinkinfoWHEREFIND_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()函數

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved