[SQLSERVER函数]把字符串分割到一个表中

本文介绍了一个SQLSERVER的用户定义函数(UDF),uf_split_string,用于将长字符串根据指定分隔符分割成多个字符串,并存储到表格中。函数接受两个参数,一个是待分割的字符串,另一个是分隔符。通过WHILE循环和CHARINDEX函数,逐个提取并插入到结果表@strs中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

===============
-- Description: 把字符串分割到一个表中
================
CREATE FUNCTION [dbo].[uf_split_string]
(
@in_str varchar(MAX),
@split  varchar(1)
)
RETURNS 
@strs TABLE 
(
c_str  varchar(100)
)
AS
BEGIN
select @in_str=ltrim(rtrim(isnull(@in_str,'')))
if(@in_str='')
begin
insert into @strs(c_str)
select ''
end

DECLARE @splitlen INT
        SET @splitlen = LEN(@split + 'a') - 2
        
        WHILE CHARINDEX(@split, @in_str) > 0
            BEGIN
                INSERT  INTO @strs ( c_str )
                        SELECT  ( LEFT(LEFT(@in_str, CHARINDEX(@split, @in_str) - 1), 100) )
                SET @in_str = STUFF(@in_str, 1, CHARINDEX(@split, @in_str) + @splitlen, '')
            END
        IF @in_str <> ''
            BEGIN 
                INSERT  INTO @strs ( c_str )
                        SELECT  LEFT(@in_str, 100)
            END 
            
return 
end
GO
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值