mysql精准模糊查询使用CONCAT加占位符(下划线“_”)的使用,直接限定了长度和格式
比如现在有张表t_user,如下:(表中只是引用某某某的话,并无恶意)
id | name |
1 | 司马懿 |
2 | 司马老贼 |
3 | 司马老贼OR司马懿 |
4 | 司马大叔 |
1.模糊查询一般用的模糊查询都是like关键词,然后再在要查的字段中用百分号“%”来查询自己想要的结果。对于上面数据,加入想查询“司马”开头的人
select * from t_user where name “司马%”;
这样查询的结果是把表中所有的数据都会查询出来。
但是,我现在需要查询以司马复姓并且名字中有1个或者两个(或者N个)的名字,显然用上面的sql是无法查询到的。
这样需要用到本篇文章要讲到的地方。用CONCAT和占位符“_”来实现。
2.在讲之前先来看下如果直接select concat的拼接会是什么样的结果
select concat("司马",“_”);###一个“_” ===============》司马_
select concat("司马",“__”,);###两个“_” ===============》司马__
select concat("司马",“__”,"OR”);###一个“_” ===============》司马__OR
可以看出,如果直接把concat的拼接当做结果查询的话,不会有任何效果,跟正常的使用concat是一样的。
所以,重要的事情要说3遍:大家不要被这里误导。大家不要被这里误导。大家不要被这里误导。
3.模糊查询中使用CONCAT和占位符“_”来精确匹配几个占位的数据(直接限定了要查数据的长度和格式)。几个下划线就是几个占位。
比如上面说的我们要查司马姓氏且名字只有一个字的人的话,我们可以用
select * from t_user where name like concat("司马","_");##一个下划线
这样我们就只能查到id为1的那条数据,而查不到其余的数据。
同理,要查司马复姓切名字有俩字的人:
select * from t_user where name like concat("司马","__"); ###俩下划线
这样我们就可以查到id为2和4的数据,而查不到其余的数据。
上面两个例子说明了此种方法是限定长度的
我们还可以做个延伸:
但是
select * from t_user where name like concat("司马","__",“OR”);##两个下划线
这样的查询是查不到任何数据的。
可是如果我们在修改成
select * from t_user where name like concat("司马","__",“OR”,"__");##前后两部分均有两个下划线,
这样我们就可以查询到id为3的数据。
所以可以看出此种方法是限定格式的
这样就达到了我们想要的“精准模糊查询”的目的
以上就是本文要说的事情,不喜勿喷。
---------------------
作者:bebmwnz
来源:CSDN
原文:https://blog.csdn.net/bebmwnz/article/details/89963996
版权声明:本文为博主原创文章,转载请附上博文链接!
mysql精准模糊查询使用CONCAT加占位符(下划线“_”)的使用,直接限定了长度和格式的更多相关文章
- mysql 实行模糊查询 一个输入值匹配多个字段和多个输入值匹配一个字段
mysql 实行模糊查询 一个输入值匹配多个字段 MySQL单表多字段模糊查询可以通过下面这个SQL查询实现 为啥一定要150字以上 真的麻烦 还不让贴代码了 SELECT * FROM `ma ...
- mysql中模糊查询的四种用法介绍
下面介绍mysql中模糊查询的四种用法: 1,%:表示任意0个或多个字符.可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示. 比如 SELECT * FROM [user] ...
- Mybatis使用MySQL进行模糊查询时输入中文检索不到结果
Mybatis使用MySQL进行模糊查询时输入中文检索时,需要在jdbcURL后增加参数 ?useUnicode=true&characterEncoding=UTF-8
- 下面介绍mysql中模糊查询的四种用法:
下面介绍mysql中模糊查询的四种用法: 1,%:表示任意0个或多个字符.可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示. 比如 SELECT * FROM [user] ...
- mysql关联模糊查询他表字段
如下:订单表关联了用户的id(多个),要根据用户名模糊查询订单信息,但是订单表只有id.创建视图用不着,咱也没权限.于是如下 SELECT * FROM ( SELECT cu.id AS 'id', ...
- mybatis中使用mysql的模糊查询字符串拼接(like)
方法一: <!-- 根据hid,hanme,grade,模糊查询医院信息--> 方法一: List<Hospital> getHospitalLike(@Param(" ...
- mysql的模糊查询
mysql模糊查询like/REGEXP(1)like / not like MySql的like语句中的通配符:百分号.下划线和escape %:表示任意个或多个字符.可匹配任意类型和长度的字符. ...
- 【mysql】模糊查询的使用
1.like/not like 关键字的模糊查询(SQL模式) 基础模板: SELECT * FROM test WHERE name LIKE '%你好_' :匹配 ...
- MySQL 一般模糊查询的几种用法
1.%:表示零个或多个字符.在某些情况下需要中文查询,一般用两个%来查询,即%%: select * from user where name like %五%; -->表示:查询user表中的 ...
随机推荐
- ajax基础------备忘
1:register.jsp <%@ page language="java" contentType="text/html; charset=UTF-8" ...
- 【JVM学习笔记】系统类加载器
可以通过“java.system.class.loader"属性指定系统类加载器 默认情况下,该属性值为空: public class Test { public static void m ...
- 短路与(&&)、短路或(||)
昨晚上课,老师用了类似这样的语法 fn&&fn.call(obj) fn&&fn.call(obj) 这里的fn为回调函数.老师在课上也没过多解释这句是啥意思,然后我 ...
- C++返回对象和返回引用
我们发现,在C++中,有些成员函数返回的是对象,而有些函数返回的又是引用. 返回对象和返回引用的最主要的区别就是函数原型和函数头. Car run(const Car &) //返回对 ...
- DHCP服务+PXE自动安装系统
DHCP服务+PXE自动安装系统 DHCP安装 安装DHCP服务器 yum install dhcp -y 安装完dhcp默认无法启动,需要编辑配置文件设置分配地址范围等相关信息,服务器自身IP地址要 ...
- 纪录一次left join一对多关系而引起的BUG
纪录一次left join一对多关系而引起的BUG MySQL(11)---纪录一次left join一对多关系而引起的bug BUG背景 我们有一个订单表 和 一个 物流表 它们通过 订单ID 进行 ...
- JAVA实验报告及第九周总结
Java第九周作业 实验报告七 实验任务详情: 完成火车站售票程序的模拟. 要求: (1)总票数1000张: (2)10个窗口同时开始卖票: (3)卖票过程延时1秒钟: (4)不能出现一票多卖或卖出负 ...
- git常用命令总结——覆盖日常开发全操作
前言:Git是目前世界上最先进的分布式版本控制系统,对的,最先进! 1. 版本库,又名仓库,repository 可理解成一个目录,目录里的所有文件都可被Git管理,Git可以跟踪每个文件的修改.删除 ...
- React生命周期使用
组件的生命周期可分成三个状态: Mounting:已插入真实 DOM Updating:正在被重新渲染 Unmounting:已移出真实 DOM 生命周期的方法有: componentWillMoun ...
- [转帖]字符编码笔记:ASCII,Unicode 和 UTF-8
字符编码笔记:ASCII,Unicode 和 UTF-8 http://www.ruanyifeng.com/blog/2007/10/ascii_unicode_and_utf-8.html 转帖 ...