设为首页 收藏本站
查看: 768|回复: 0

[经验分享] sql语句中like的用法

[复制链接]

尚未签到

发表于 2018-10-17 13:28:26 | 显示全部楼层 |阅读模式
  在SQL结构化查询语言中,LIKE语句有着至关重要的作用。
  LIKE语句的语法格式是:select from 表名 where 字段名 like 对应值(子串),它主要是针对字符型字段的,它的作用是在一个字符型字段列中检索包含对应子串的。
  假设有一个数据库中有个表table1,在table1中有两个字段,分别是name和sex二者全是字符型数据。现在我们要在姓名字段中查询以“张”字开头的记录,语句如下:
  select  from table1 where name like "张"
  如果要查询以“张”结尾的记录,则语句如下:
  select  from table1 where name like "张"
  这里用到了通配符“”,可以说,like语句是和通配符分不开的。下面我们就详细介绍一下通配符。
  匹配类型  
  模式
  举例 及 代表值
  说明
  多个字符
  cc代表cc,cBc,cbc,cabdfec等
  它同于DOS命令中的通配符,代表多个字符。
  多个字符 %
  %c%代表agdcagd等
  这种方法在很多程序中要用到,主要是查询包含子串的。
  特殊字符 []
  a[]a代表aa
  代替
  单字符 ?
  b?b代表brb,bFb等
  同于DOS命令中的?通配符,代表单个字符
  单数字 #
  k#k代表k1k,k8k,k0k
  大致同上,不同的是代只能代表单个数字。
  字符范围

  • [a-z]代表a到z的26个字母中任意一个 指定一个范围中任意一个  续上
      排除 [!字符] [!a-z]代表9,0,%,*等 它只代表单个字符
      数字排除 [!数字] [!0-9]代表A,b,C,d等 同上
      组合类型 字符[范围类型]字符 cc[!a-d]#代表ccF#等 可以和其它几种方式组合使用
      假设表table1中有以下记录:
      name                          sex
      张小明              男
      李明天       男
      李a天       女
      王5五       男
      王清五           男
  下面我们来举例说明一下:
  例1,查询name字段中包含有“明”字的。
  select from table1 where name like '%明%'
  例2,查询name字段中以“李”字开头。
  select  from table1 where name like '李'
  例3,查询name字段中含有数字的。
  select  from table1 where name like '%[0-9]%'
  例4,查询name字段中含有小写字母的。
  select from table1 where name like '%[a-z]%'
  例5,查询name字段中不含有数字的。
  select  from table1 where name like '%[!0-9]%'
  以上例子能列出什么值来显而易见。但在这里,我们着重要说明的是通配符“”与“%”的区别。
  很多朋友会问,为什么我在以上查询时有个别的表示所有字符的时候用"%"而不用“”?
  先看看下面的例子能分别出现什么结果:
  select from table1 where name like
  select  from table1 where name like %明%
  大家会看到,前一条语句列出来的是所有的记录,而后一条记录列出来的是name字段中含有“明”的记录,所以说,当我们作字符型字段包含一个子串的查询时最好采用“%”而不用“”,用“”的时候只在开头或者只在结尾时,而不能两端全由“*”代替任意字符的情况下。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-622859-1-1.html 上篇帖子: sql造数技巧 下篇帖子: sql语句中like的用法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表