加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql-server – 使用SELECT仅获取SQL Server中包含字母数字数据(

发布时间:2020-12-12 06:49:20 所属栏目:MsSql教程 来源:网络整理
导读:我试图过滤一些SQL服务器数据,并要求具有以下条件的结果: 字段中包含字母数字字符,不区分大小写 该字段有一定的标点符号(撇号和连字符) 该字段没有空格 有没有一种有效的方法在SQL Server中使用CHAR执行此操作,还是有人有更好的解决方案? 解决方法 这使用双
我试图过滤一些SQL服务器数据,并要求具有以下条件的结果:

>字段中包含字母数字字符,不区分大小写
>该字段有一定的标点符号(撇号和连字符)
>该字段没有空格

有没有一种有效的方法在SQL Server中使用CHAR执行此操作,还是有人有更好的解决方案?

解决方法

这使用双倍负片仅过滤到所需的字符范围

期望范围之外的任何字符都可以从LIKE中获得真实.如果字符串仅包含所需范围内的字符,则LIKE给出false.然后另一个不

WHERE
   SomeCol NOT LIKE '%[^a-z0-9-'']%'

注意:我在这里使用单引号

默认情况下,SQL Server不区分大小写.如果需要,添加COLLATE子句

SomeCol COLLATE Latin1_General_CI_AS NOT LIKE '%[^a-z0-9-']%'

或改变范围

SomeCol NOT LIKE '%[^a-zA-Z0-9-']%'

或者,如果你想包括?= a

SomeCol COLLATE Latin1_General_CI_AI NOT LIKE '%[^a-z0-9-']%'

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读