sqlserver 拼接字符串分割
CREATE FUNCTION [dbo].[fnQuerySplit]
(
@string VARCHAR(MAX) ,--待分割字符串
@separator VARCHAR(255)--分割符
)
RETURNS @array TABLE ( item VARCHAR(255) )
AS
BEGIN
DECLARE @begin INT ,
@end INT ,
@item VARCHAR(255);
SET @begin = 1;
SET @end = CHARINDEX(@separator, @string, @begin);
WHILE ( @end <> 0 )
BEGIN
SET @item = SUBSTRING(@string, @begin, @end - @begin);
INSERT INTO @array
( item )
VALUES ( @item );
SET @begin = @end + 1;
SET @end = CHARINDEX(@separator, @string, @begin);
END;
SET @item = SUBSTRING(@string, @begin, LEN(@string) + 1 - @begin);
IF ( LEN(@item) > 0 )
INSERT INTO @array
( item
)
VALUES ( SUBSTRING(@string, @begin, LEN(@string) + 1 - @begin)
);
RETURN;
END;
CREATE FUNCTION [dbo].[Fun_String2Table]
(
@str NVARCHAR(MAX) ,
@split NVARCHAR(10)
)
RETURNS @table TABLE ( [item] NVARCHAR(MAX) )
AS
BEGIN
IF LEN(@split) = 0
BEGIN
SET @split = N',';
END; DECLARE @xml XML;
SET @xml = CONVERT(XML, '<x><![CDATA['
+ REPLACE(CONVERT(VARCHAR(MAX), @str), @split,
']]></x><x><![CDATA[') + ']]></x>'); INSERT INTO @table
SELECT item
FROM ( SELECT c.value('text()[1]', 'nvarchar(4000)') [item]
FROM @xml.nodes('/x') t ( c )
) t
WHERE item IS NOT NULL; RETURN;
END;
CREATE FUNCTION [dbo].[f_split]
(
@SourceSql NVARCHAR(MAX) ,
@StrSeprate NVARCHAR(10)
)
RETURNS @temp TABLE ( value NVARCHAR(100) )
AS
BEGIN
DECLARE @i INT;
SET @SourceSql = RTRIM(LTRIM(@SourceSql));
SET @i = CHARINDEX(@StrSeprate, @SourceSql);
WHILE @i >= 1
BEGIN
INSERT @temp
VALUES ( LEFT(@SourceSql, @i - 1) );
SET @SourceSql = SUBSTRING(@SourceSql, @i + 1,
LEN(@SourceSql) - @i);
SET @i = CHARINDEX(@StrSeprate, @SourceSql);
END;
IF @SourceSql <> '\'
INSERT @temp
VALUES ( @SourceSql );
RETURN;
END;
fnQuerySplit:

Fun_String2Table:

f_split:

因为每次执行都是不一样的时间,所以综合下来,
Fun_String2Table 是最快的
sqlserver 拼接字符串分割的更多相关文章
- sqlserver 自定义字符串分割函数.
--SQL Server Split函数 --Author: sq --说明:被分割后的字段为:short_str --支持分割符多字节 --使用方法 --Select * FROM splits(' ...
- sqlserver 拼接字符串
SELECT CAST(USER_ID AS VARCHAR) + ',' FROM dbo.AUTH_USER FOR XML PATH('');
- SQLServer实现split分割字符串到列
网上已有人实现sqlserver的split函数可将字符串分割成行,但是我们习惯了split返回数组或者列表,因此这里对其做一些改动,最终实现也许不尽如意,但是也能解决一些问题. 先贴上某大牛写的sp ...
- iOS开发-- 字符串分割、拼接
---------------------字符串分割实例---------------------NSString * ptr = @"I am a man"; //将字符串整体作 ...
- Obj-C数组以及字符串拼接与分割
本文转载至 http://mobile.51cto.com/iphone-392148.htm Obj-C只是增加了一点“特殊语料”的C语言,所以可以用printf()代替NSLog().但我们建议使 ...
- java以逗号为分割符拼接字符串的技巧
java以逗号为分割符拼接字符串的技巧 答: 不用那么多if判断,让人思维混乱,直接到最后使用deleteCharAt方法去除最后一个逗号即可. 实现代码如下所示: StringBuffer sb ...
- NSString用法,object-C数组以及字符串拼接和分割
一.介绍使用NSString创建一个字符串的代码如下: #import <Foundation/Foundation.h>int main (int argc, char *argv[]) ...
- mysql 字符串分割 和 动态执行拼接sql
本人以前主要用的是MSSQL,最近项目在使用MYSQL,自己是一个 典型的小白.今天就记录一下 一个mysql存储过程,里面需要分割字符串和 动态执行sql语句. 关于字符串 分割我开始使用 LOCA ...
- 工作中用到的oracle字符串分割整理
oracle部分: 定义类型(用于字符串分割): create or replace TYPE "STR_SPLIT" IS TABLE OF VARCHAR2 (4000); 字 ...
随机推荐
- 域账号修改后,导致vs中的git连接失败
域账号修改后,导致vs中的git连接失败, fatal: Authentication failed for https://blog.csdn.net/qq_34665539/article/det ...
- 深入理解隐马尔可夫(HMM)模型
1.安装依赖包hmmlearn 直接pip install hmmlearn可能会报错(安装这个模块需要使用C环境编译) 可以尝试用 conda install -c omnia hmmlearn安装 ...
- Mac安装7Z以及Mac下查看隐藏文件夹
一:Mac下安装7Z: 1:brew直接安装解压工具 $ brew search 7z 会搜索到: ==> Formulae p7zip 2:$ brew install p7zip ...
- execl文件读取封装
前言:做自动化常用的公共方法 注:第一次使用记得先 pip install xlrd 模块import xlrd class ReadExecl(): def __init__(self,filena ...
- php取上个月月初和月末时间戳
$thismonth = date('m');$thisyear = date('Y');if ($thismonth == 1) { $lastmonth = 12; $lastyear = $th ...
- coverage代码覆盖率的使用~~
我们看下代码覆盖率的统计~,这个不必太揪心,觉得可以帮助你优化代码,可以看看,也不要带在意~ 1.先在cmd命令窗口在线安装coverage pip install coverage 2.安装完毕后我 ...
- 在ROS系统下,获取tango的RGBD信息和Pose信息
Project Tango 是从Google 的 Advanced Technology and Projects group (ATAP) 孵化出来的一个项目,诚如ATAP高级工程师Johnny L ...
- json 和对象互相转换
json 和对象互相转换 导入 Jar 包: import com.fasterxml.jackson.databind.ObjectMapper; Maven 地址: <!-- https:/ ...
- [转帖]详解Linux系统inode原理--硬链接、软链接、innodb大小和划分等
详解Linux系统inode原理--硬链接.软链接.innodb大小和划分等 原创 波波说运维 2019-07-17 00:03:00 https://www.toutiao.com/i6713116 ...
- Win7 JavaEE 安装
新建四个目录 D:\ApacheServer\eclipse 存放eclipse D:\ApacheServer\jdk jdk安装目录 D:\ApacheServer\apache-tomcat 存 ...