方法一:like
select * from 表名 where 字段名 like %字符%;
方法二:find_in_set()
利用mysql 字符串函数 find_in_set();
select * from users where find_in_set('字符', 字段名);
这样是可以的,怎么理解呢?
mysql有很多字符串函数 find_in_set(str1,str2)函数是返回str2中str1所在的位置索引,str2必须以,分割开。
复制代码
注:当str2为no1:“3,6,13,24,33,36”,no2:“13,33,36,39”时,判断两个数据中str2字段是否包含‘3’,该函数可好解决
mysql > select find_in_set()('3','3,6,13,24,33,36') as test;
-> 1
mysql > select find_in_set()('3','13,33,36,39') as test;
-> 0
复制代码
方法三:locate(字符,字段名)
使用locate(字符,字段名)函数,如果包含,返回>0的数,否则返回0 ,
它的别名是 position in
select * from 表名 where locate(字符,字段)
select * from 表名 where position(字符 in 字段);
例子:判断site表中的url是否包含'http://'子串,如果不包含则拼接在url字符串开头
update site set url =concat('http://',url) where locate('http://',url)=0
注意mysql中字符串的拼接不能使用加号+,用concat函数
方法四:instr(字段,字符)
select * from 表名 where instr(字段,字符)
另外,笔者查看了以上sql的执行计划(不包含find_in_set),发现都是:
网上说模糊查询 用 locate 速度快,不知道结论怎么来的,可能是大数据量的情况下吧。
网站做seo优化需要掌握的知识重庆[转载]企业网站建设:网络公司VS个人两大网络营销技巧做好,流量持续上升!分享一下我的企业网站seo工作字体是做网站重点关注的一环网站建设中网站怎么选择空间呢?选择共享主机时的5大实践找这些网络公司网站建设费用都要老银子了,啥原因差这么多?