mysql中的 IN FIND_IN_SET LIKE 正则

FIND_IN_SET 

假如字符串str 在由N 子链组成的字符串列表strlist 中,则返回值的范围在 1 到 N 之间。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串 。如果第一个参数是一个常数字符串,而第二个是type SET列,则   FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。

mysql> SELECT FIND_IN_SET('b','a,b,c,d'); //-> 2

原来以为mysql可以进行这样的查询
select id, list, name from table where 'daodao' IN (list);      (一)
注:1. table含有三个字段id:int,  list:varchar(255),  name:varchar(255)
实际上这样是不行的,这样只有当'daodao'是list中的第一个元素时,查询才有效,否则都的不到结果,即使'daodao'真的再list中

CREATE TABLE `test` (
  `id` int(8) NOT NULL auto_increment,
  `name` varchar(255) NOT NULL,
  `list` varchar(255) NOT NULL,
  PRIMARY KEY  (`id`)
)
INSERT INTO `test` VALUES (1, 'name', 'daodao,xiaohu,xiaoqin');
INSERT INTO `test` VALUES (2, 'name2', 'xiaohu,daodao,xiaoqin');
INSERT INTO `test` VALUES (3, 'name3', 'xiaoqin,daodao,xiaohu'); 
test1:sql = select * from `test` where 'daodao' IN (`list`);
得到结果空值.
test2:sql = select * from `test` where FIND_IN_SET('daodao',`list`);
得到三条数据。
1, 'name', 'daodao,xiaohu,xiaoqin'  
2, 'name2', 'xiaohu,daodao,xiaoqin'
3, 'name3', 'xiaoqin,daodao,xiaohu' 

IN

多个字段同时使用

select * from user where (user_id,type) in ((568,6),(569,6),(600,8));

REGEXP | RLIKE

要查找名称只包含10个字符的产品,可以使用’^‘和’$‘来匹配产品名称的开头和结尾,并重复{10}次任何字符.,作为以下查询

SELECT productname FROM products WHERE productname REGEXP '^.{10}$';

查询name包含php或者sql的所有数据

SELECT name FROM dev WHERE name  REGEXP 'PHP|SQL';
#包含字母数字_
select call_vendor from phone_monthly where call_vendor regexp '^[A-Za-z0-9_]+$'
#手机号
SELECT DISTINCT called from ss where right(called,11) REGEXP '^[1][3-9]{1}[0-9]{9}$'

Like | 转义

通配符的分类:
%百分号通配符: 表示任何字符出现任意次数 (可以是0次).
_下划线通配符:表示只能匹配单个字符,不能多也不能少,就是一个字符.

like '_a_'    //三位且中间字母是a的
like '_a'     //两位且结尾字母是a的
like 'a_'     //两位且开头字母是a的

使用LIKE关键字进行模糊查询时,“%”“_”单独出现时,会被认为是通配符,这个查询条件就会失效。

在进行查询,只需要加一个转义字符" \ "进行转义即可:

SELECT * FROM sys_user where name like '%\_%'

在进行查询,使用ESCAPE关键字

SELECT * FROM sys_user where name like '%#_%' ESCAPE '#'

INSTR 

使用内部函数INSTR,代替传统的LIKE方式查询,并且速度更快。 
INSTR()函数返回字符串中子字符串第一次出现的位置。如果在str中找不到子字符串,则INSTR()函数返回零(0)。 

SELECT * FROM sys_user where INSTR(name, '_')>0

查找用户名称name中包含_的用户

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值