SqlServer Split函数
2024-10-18 08:31:04
Create FUNCTION [dbo].[SplitToTable] (
@SplitString nvarchar(max),
@Separator nvarchar(10)=' '
)
RETURNS @SplitStringsTable TABLE ( [id] int identity(1,1), [value] nvarchar(max) )
AS
BEGIN
DECLARE @CurrentIndex int;
DECLARE @NextIndex int;
DECLARE @ReturnText nvarchar(max);
SELECT @CurrentIndex=1;
WHILE(@CurrentIndex<=len(@SplitString))
BEGIN
SELECT @NextIndex=charindex(@Separator,@SplitString,@CurrentIndex);
IF(@NextIndex=0 OR @NextIndex IS NULL)
SELECT @NextIndex=len(@SplitString)+1;
SELECT @ReturnText=substring(@SplitString,@CurrentIndex,@NextIndex-@CurrentIndex);
INSERT INTO @SplitStringsTable([value]) VALUES(@ReturnText);
SELECT @CurrentIndex=@NextIndex+1;
END
RETURN;
END
使用
declare @TR NVARCHAR(50)
declare @TRS NVARCHAR(1000)
SET @TRS='123,456,789'
set @TR=(select top 1 VALUE from dbo.SplitToTable(@TRS,',') order by NEWID()) --最外面一定要加括号
PRINT(@TR)
最新文章
- 王宝强新片P2P风波持续发酵,互金真的前途未卜?
- 转使用chrome命令行:disable-web-security 实现浏览器跨域
- Python开发【杂货铺】:五个知识点搞定作用域
- C语言 文件操作8--fputs()和fgets()
- vb.net三层实现登录例子
- C++中new和delete来创建和释放动态数组
- SharePoint自动化系列——Add/Remove ";Record"; from items
- sorl维护索引库sorl4j的使用
- error C2061: syntax error : identifier &#39;__RPC__out_xcount_part&#39;
- django初探
- Java之戳中痛点 - (6)避免类型自动转换,例如两个整数相除得浮点数遇坑
- win10 uwp 判断文件存在
- BZOJ4001[TJOI2015]概率论——卡特兰数
- centos 安装 TortoiseSVN svn 客户端
- Accer 4752G添加固态硬盘 双系统
- [转]logging使用
- MySQL 日期类型及默认设置 (除timestamp类型外,系统不支持其它时间类型字段设置默认值)
- [LeetCode]Find Pivot
- Gogeos安装
- 添加ASP.NET网站资源文件夹