博客
关于我
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/

你可能感兴趣的文章
Netty工作笔记0032---零拷贝AIO内容梳理
查看>>
Netty工作笔记0033---Netty概述
查看>>
Netty工作笔记0034---Netty架构设计--线程模型
查看>>
Netty工作笔记0035---Reactor模式图剖析
查看>>
Netty工作笔记0036---单Reactor单线程模式
查看>>
Netty工作笔记0037---主从Reactor多线程
查看>>
Netty工作笔记0038---Netty模型--通俗版
查看>>
Netty工作笔记0039---Netty模型--详细版
查看>>
Netty工作笔记0040---Netty入门--服务端1
查看>>
Netty工作笔记0041---Netty入门--服务端2
查看>>
Netty工作笔记0042---Netty入门--编写客户端
查看>>
Netty工作笔记0043---单Reactor多线程模式
查看>>
Netty工作笔记0044---Netty案例源码分析
查看>>
Netty工作笔记0044---scheduledTaskQueue
查看>>
Netty工作笔记0045---Netty模型梳理
查看>>
Netty工作笔记0045---异步模型原理剖析
查看>>
Netty工作笔记0046---TaskQueue自定义任务
查看>>
Netty工作笔记0046---异步模型原理剖析
查看>>
Netty工作笔记0047---Http服务程序实例
查看>>
Netty工作笔记0048---Http服务过滤资源
查看>>