博客
关于我
SQL Server不用创建函数,实现Split函数指定分隔符分割以及判断是否为整数
阅读量:543 次
发布时间:2019-03-07

本文共 715 字,大约阅读时间需要 2 分钟。

一、SQL server按指定分隔符分割

例如有一个字段是姓名/电话,分隔符是"/",姓名长度不一,网上很多教程都是创建函数来实现,其实不用创建函数也可以实现,这里只需要用到charindex这个函数就够了。

CHARINDEX用法:

CHARINDEX ( expression1 , expression2 [ , start_location ] )

   Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始位置

例子:

用法

select left([info],charindex('/',[info])-1) as names ,right([info],len([info])-charindex('/',[info])) as phone

from #test 

效果:

可能有的人会问,如果是多个逗号隔开的,应该怎么处理,类似这样的,想按照逗号分开成多行,逗号个数不一定:

代码:

select  groupname,value

  from #test
  cross apply string_split(names,',')

效果:

二、判断是否为整数

 PATINDEX()函数用法

 PATINDEX ( '%pattern%' , expression )

模糊查找其pattern字符串是否在expression能找到,能找到返回其第一次出现的位置

例子:

用法:

select info, case when PATINDEX('%[^0-9]%', info)=0 then '整数' else '非整数' end

from #test

效果;

转载地址:http://jimjz.baihongyu.com/

你可能感兴趣的文章
nativescript(angular2)——ListView组件
查看>>
NativeWindow_01
查看>>
Native方式运行Fabric(非Docker方式)
查看>>
Nature | 电子学“超构器件”, 从零基础到精通,收藏这篇就够了!
查看>>
Nature和Science同时报道,新疆出土四千年前遗骸完成DNA测序,证实并非移民而是土著...
查看>>
Nature封面:只低一毫米,时间也会变慢!叶军团队首次在毫米尺度验证广义相对论...
查看>>
Nat、端口映射、内网穿透有什么区别?
查看>>
Nat、端口映射、内网穿透有什么区别?
查看>>
nat打洞原理和实现
查看>>
NAT技术
查看>>
NAT模式/路由模式/全路由模式 (转)
查看>>
NAT模式下虚拟机centOs和主机ping不通解决方法
查看>>
NAT的两种模式SNAT和DNAT,到底有啥区别?
查看>>
NAT的全然分析及其UDP穿透的全然解决方式
查看>>
NAT类型与NAT模型详解
查看>>
NAT网络地址转换配置实战
查看>>
NAT网络地址转换配置详解
查看>>
navbar navbar-inverse 导航条设置颜色
查看>>
Navicat for MySQL 命令列 执行SQL语句 历史日志
查看>>
Navicat for MySQL 查看BLOB字段内容
查看>>