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

作者: fallenleav_2c59 | 来源:发表于2020-03-18 14:52 被阅读0次

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

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

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

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

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

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

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 '%龙%'

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

select * from user where realname like '林_'

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

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

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

  select * from user where realname like '_林'

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

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

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

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”、…… 

五.查询内容包含通配符时 

由于通配符的缘故,导致我们查询特殊字符“%”、“_”、“[”的语句无法正常实现,而把特殊字符用“[ ]”括起便可正常查询。据此我们写出以下函数: 

function sqlencode(str) str=replace(str,"';","';';") 

str=replace(str,"[","[[]") ';此句一定要在最先 str=replace(str,"_","[_]") str=replace(str,"%","[%]") sqlencode=str end function

相关文章

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

    mysql中模糊查询的四种用法: 一.%:表示任意0个或多个字符。可匹配任意类型和长度的字符,有些情况下若是中文,...

  • mysql 中模糊查询

    MySQL中 使用like关键字进行模糊查询,like关键字通常用在where条件查询子句中,like字句通常配合...

  • mysql 中模糊查询的四种用法介绍2018-06-26

    *********************************************************...

  • SSM-mybatis

    模糊查询 占位符的用法 mybatis使用com.mysql.cj.jdbc.Driver会出现的一些问题 我终于...

  • Elastic检索技巧总结

    常用的检索类型 在mysql中,我们常用的查询 可能就是 精准查询 模糊查询 范围查询 等等,那么在es中,有哪...

  • mongodb 常用语句大全

    参考[https://www.jianshu.com/p/ffcb29301a02] 模糊查询 mySql中模糊查...

  • SQL之模糊查询的四种用法

    MySql 使用 like关键字 进行模糊查询,like关键字 通常用在 where条件查询,like关键字 通常...

  • MySQL

    mysql递归查询组织机构mysql 递归查询 MySQL教程之concat以及group_concat的用法 M...

  • MYSQL模糊查询

    1.公式select * from 表名 where 字段 Like 条件2.%可以匹配0个或者多个字符eg:my...

  • mySQL——模糊查询

    正则表达式在模式开始处使用“^”或在模式的结尾用“$”。 为了找出以“三”开头的名字,使用“^”匹配名字的开始。S...

网友评论

    本文标题:mysql中模糊查询的四种用法:

    本文链接:https://www.haomeiwen.com/subject/jzoqyhtx.html