加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 数据库 > MsSql > 正文

sql-server – 使用SELECT仅获取SQL Server中包含字母数字数据(和某些标点符号)的字段

发布时间:2020-05-24 12:04:58 所属栏目: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-']%'

(编辑:安卓应用网)

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

    推荐文章
      热点阅读