自己动手丰衣足食,DIY SQL字符串分解函数Split

数据库
C#中和JavaScript中都有相应的分离字符串的Split函数,就想当然的以为SQL中也会有类似的函数,结果查了半天的MSSQL帮助文档,也没找到。没办法,只好自己写了

前段时间,在做一个可以批量审核或删除数据的功能时,遇到这么个问题:

因为审核或删除操作是在存储过程进行的,所以,就打算将选中的数据的主键拼成字符串,传到存储过程进行分离,再继续处理。

C#中和JavaScript中都有相应的分离字符串的Split函数,就想当然的以为SQL中也会有类似的函数,结果查了半天的MSSQL帮助文档,也没找到。没办法,只好自己写了,在网上搜了下相关的,看了一两篇关于SQL分离字符串的自定义函数的文章,结果,有点失望,可能是自己水平差,或者是因为人家的代码没写注释吧,总之就是看着挺吃力的,还没看完就决定自己写了。。。

思路很简单:在需要分解的字符串中,如果存在指定的分隔符,则将***个分隔符前面的字符串取出,存入表内,然后在需要分解的字符串中将已取出的字符串及***个分隔符删除,然后继续下一次分解(如果还存在指定的分隔符,就分解)

以下是SQL:

  1. -- ============================================= 
  2.  -- Author:        Henson 
  3.  -- Create date:   2011-04-20 
  4.  -- Description:   字符串分离函数 
  5.  -- ============================================= 
  6.  ALTER FUNCTION [dbo].[Split]  
  7.  ( 
  8.      @strText varchar(3000),--待分离的原字符串 
  9.      @strSplit varchar(100)--分隔符 
  10.  ) 
  11.  RETURNS @temp Table 
  12.  ( 
  13.      ID int IDENTITY PRIMARY KEY
  14.      SingleVal varchar(1000) 
  15.  ) 
  16.  AS 
  17.  BEGIN 
  18.      Declare @intLen int --用来存储待分离原字符串长度 
  19.      Declare @intSplitLen int --分隔符长度 
  20.      Declare @intIndex int --用来存储分离字符串在原字符串的位置 
  21.      Declare @strVal varchar(1000)--用来存储分离出来后的字符串 
  22.      --获取原字符串的长度 
  23.      Set @intLen = LEN(RTRIM(LTRIM(@strText))) 
  24.      Set @intSplitLen = LEN(RTRIM(LTRIM(@strSplit))) 
  25.      --原字符串不为空,才继续分离 
  26.      If(@intLen > 0) 
  27.      Begin 
  28.          --循环原字符串,直至原字符串被分离完毕 
  29.          While CHARINDEX(@strSplit,@strText)>0 
  30.          Begin 
  31.              --获取分离字符串在原字符串的位置 
  32.              Set @intIndex = CHARINDEX(@strSplit,@strText) 
  33.              --获取分离出的字符串,并插入表中 
  34.              Set @strVal = RTRIM(LTRIM(LEFT(@strText,@intIndex-1))) 
  35.              if(LEN(@strVal)>0) 
  36.              Begin 
  37.                  Insert Into @temp (SingleVal) values(@strVal) 
  38.              End 
  39.              --分离后,将分离出的字符串(包括分隔符)从原字符串中删除 
  40.              Set @strText = Substring(@strText,@intIndex+@intSplitLen,@intLen-@intIndex) 
  41.              --重新设置原字符串的长度 
  42.              Set @intLen = LEN(@strText) 
  43.          End 
  44.          --如果分离后的原字符串依然不为空,则也应该插入表中 
  45.          if(LEN(RTRIM(LTRIM(@strText)))>0) 
  46.          Begin 
  47.              Insert Into @temp (SingleVal) values(@strText) 
  48.          End 
  49.      End 
  50.      return 
  51.  END 

(分隔符允许是多位的)

按一般的习惯来说,在组织多个字符串时,一般都是这种写法:strKeys += strSingleKey + ",";

所以可能最终该字符串可能会以逗号结尾,如果组织完成后,将结尾的逗号去掉了,那就不会以逗号结尾,所以,在循环分解完成后,如果剩下的原字符串中(去除左右空格后),如果还有内容 ,则也应该存入表中。  

可能我这种写法不是***的,也可能会有问题,如确实有需要改进的,还请指出,不胜感激!!!

原文链接:http://www.cnblogs.com/uphenson/archive/2011/07/18/2109452.html

【编辑推荐】

  1. SQL Server如何动态生成分区脚本
  2. 手把手教你建立SQL数据库的表分区
  3. 说说抽象SQL(参数化)的查询
  4. 浅述远程Service Broker的实现
责任编辑:艾婧 来源: 博客园
相关推荐

2022-08-29 14:22:03

bpmn.jsVue流程

2010-11-08 17:07:41

SQL Server字

2010-09-09 11:48:00

SQL函数字符串

2010-09-06 17:30:46

SQL函数

2021-03-14 15:07:55

SQLServer数据库字符串

2010-09-13 14:55:09

sql server字

2014-01-02 16:14:10

PostgreSQL字符串

2011-07-12 13:01:33

2020-09-29 12:13:46

SQL引擎底层

2009-11-27 09:05:50

PHP函数split(

2010-10-21 15:26:35

SQL Server字

2010-10-09 11:54:46

MySQL字符串

2010-09-06 17:26:54

SQL函数

2010-04-09 18:15:47

Oracle 字符串

2010-07-14 16:35:52

Perl字符串处理函数

2010-11-26 10:14:40

MySQL repla

2009-08-06 16:01:09

C#字符串函数大全

2010-06-28 15:18:51

SQL Server

2009-11-24 09:55:44

PHP字符串函数

2011-03-22 10:44:20

SQL Server数拆分字符串函数
点赞
收藏

51CTO技术栈公众号