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

你可能感兴趣的文章
No qualifying bean of type ‘com.netflix.discovery.AbstractDiscoveryClientOptionalArgs<?>‘ available
查看>>
No resource identifier found for attribute 'srcCompat' in package的解决办法
查看>>
no session found for current thread
查看>>
No static resource favicon.ico.
查看>>
no such file or directory AndroidManifest.xml
查看>>
No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
查看>>
NO.23 ZenTaoPHP目录结构
查看>>
no1
查看>>
NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
查看>>
NOAA(美国海洋和大气管理局)气象数据获取与POI点数据获取
查看>>
NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
查看>>
node
查看>>
node exporter完整版
查看>>
node HelloWorld入门篇
查看>>
Node JS: < 一> 初识Node JS
查看>>
Node JS: < 二> Node JS例子解析
查看>>
Node Sass does not yet support your current environment: Linux 64-bit with Unsupported runtime(93)解决
查看>>
Node Sass does not yet support your current environment: Windows 64-bit with Unsupported runtime(72)
查看>>
Node 裁切图片的方法
查看>>
node+express+mysql 实现登陆注册
查看>>