mysql搜索名字语法_mysql中模糊查询语法是什么?

本文详细介绍了MySQL中的LIKE模糊查询操作,包括%通配符用于匹配任意数量字符,_通配符匹配单个字符,以及[]和[^]用于指定特定字符或范围。通过各种实例展示了如何使用LIKE子句来筛选包含特定字符或模式的数据记录,适用于数据检索和过滤场景。
摘要由CSDN通过智能技术生成

1ab520c48cc6bcb418e8bba4a85d061b.png

MySQL LIKE模糊查询

我们知道在 MySQL 中使用 SQL SELECT 命令来读取数据, 同时我们可以在 SELECT 语句中使用 WHERE 子句来获取指定的记录。

WHERE 子句中可以使用等号 = 来设定获取数据的条件,如 "runoob_author = 'RUNOOB.COM'"。

但是有时候我们需要获取 runoob_author 字段含有 "COM" 字符的所有记录,这时我们就需要在 WHERE 子句中使用 SQL LIKE 子句。

SQL LIKE 子句中使用百分号 %字符来表示任意字符,类似于UNIX或正则表达式中的星号 *。

如果没有使用百分号 %, LIKE 子句与等号 = 的效果是一样的。

语法

以下是 SQL SELECT 语句使用 LIKE 子句从数据表中读取数据的通用语法:SELECT field1, field2,...fieldN

FROM table_name

WHERE field1 LIKE condition1 [AND [OR]] filed2 = 'somevalue'你可以在 WHERE 子句中指定任何条件。

你可以在 WHERE 子句中使用LIKE子句。

你可以使用LIKE子句代替等号 =。

LIKE 通常与 % 一同使用,类似于一个元字符的搜索。

你可以使用 AND 或者 OR 指定一个或多个条件。

你可以在 DELETE 或 UPDATE 命令中使用 WHERE...LIKE 子句来指定条件。

mysql中模糊查询的四种用法:

一.%:表示任意0个或多个字符。可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百 分号(%%)表示。

*注:like '%龙%':查询出所有含有“龙”的记录

1. 所查询字段 + like '%龙%'

eg:select * from user where realname like '%龙%'

把含有“龙”字的 realname 字段搜索出来

9791ee012a4761ed7707a53baa25d3d4.png

2. 所查询字段 + like '%龙%' and 所查询字段 + like '%文%'

eg: select * from user where realname like '%龙%' and realname like '%文%'

= 所查询字段 + like '%文%' and 所查询字段 + like '%龙%'

eg: select * from user where realname like '%文%' and realname like '%龙%'

16f29de3bb17f5f66087f5179b45d39b.png

3. 查询出既含有“龙”同时又有“文”的所有记录

realname like'%龙%文%':查询所有“龙文”记录,可以是“龙_文”“_龙文”“龙文_”

“龙”字须在前面,“文”字在后面

select * from user where realname like '%龙%文%'

5de2b0c060cbbc4c6992ecec21876811.png

realname like'%文%龙%':查询所有“文龙”记录,可以是“文_龙”“_文龙”“文龙_”

“文”字须在前面,“龙”字在后面

select * from user where realname like '%文%龙%'

dc89615c85fb247b6d0b62aab65abd87.png

二._: 表示任意单个字符。匹配单个任意字符,它常用来限制表达式的字符长度语句:

1.查询出中间含有“林”字的realname字段(前提:名字三个字)

select * from user where realname like '_林_'

=select * from user where realname like '%_林_%'

只能查询出类似“余林文”这样的realname为三个字且中间一个字为:“林”

b516e2ac10973052eb24129fc25e28e3.png

2.查询出姓林的姓名(名字三个字)

select * from user where realname like'林__'(这里有两横杠)

=select * from user where realname like '%林__%'(这里有两横杠)

查询出姓“林”的realname,且realname的字数必须为3

fe945c5481d66558a0b53405e3ea2ef9.png

3.查询名字最后一个字为“林”的姓名(名字三个字)

select * from user where realname like '__林'(这里有两横杠)

= select * from user where realname like '%__林%'(这里有两横杠)

查询出姓名最后一个字为“林”的姓名,且realname的字数必须为3

801766fe1e31d130706fc63299f2f1e8.png

4.查询出姓林的姓名(姓名只有两个字)

select * from user where realname like '林_'

0c33cafc8605593ab7bfffff99fe81ba.png

查询出姓林的姓名(姓名可以是两个字,也可以是三个字)

select * from user where realname like '%林_%'

56f6aaf21bb99a7d75e3df172bf5db21.png

5.查询名字最后一个字为“林”的姓名(姓名只有两个字)

select * from user where realname like '_林'

dc999e1f197ca79690a8feae64997686.png

查询名字最后一个字为“林”的姓名(姓名可以有两个字,也可以是三个字)

select * from user where realname like '%_林%'

15177310a683294137acc378beeb3efd.png

三.[ ]:表示括号内所列字符中的一个(类似正则表达式)。指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。

select * from user where realname like '[张蔡王]杰'

查询出“张杰”,“蔡杰”,“王杰”(而不是“张蔡王杰”)

如 [ ] 内有一系列字符(01234、abcde之类的)则可略写为“0-4”、“a-e”

select * from user where realname like '林[1-9]'将会查询出“林1”“林2”......“林9”

四.[^ ] :表示不在括号所列之内的单个字符。其取值和 [] 相同,但它要求所匹配对象为指定字符以外的任一个字符。

select * from user where realname like '[^张蔡王]杰'

查询出不姓“张”,“蔡”,“王”的“林杰”,“赵杰”等

select * from user where realname like '林[^1-4]'

将排除“林1”到“林4”,寻找“林5”、“林6”、……

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值