SQL server字符串分割成表-表分割为字符串

Posted 博客燕

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL server字符串分割成表-表分割为字符串相关的知识,希望对你有一定的参考价值。

 --字符串根据特定字符分割成表数据
create  function [dbo].[f_split](@SourceSql varchar(8000),@StrSeprate varchar(10))
returns @temp table(a varchar(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

 把查出来的表一个单列转换成字符串用,隔开。

create FUNCTION [dbo].[f_GetUserIdStr]
(
@userId dbo.UserIdInfo READONLY
)
RETURNS NVARCHAR(4000)
AS
BEGIN

DECLARE @uidStr NVARCHAR(4000)

SET @uidStr =STUFF((SELECT ‘,‘+CAST(UserId AS NVARCHAR(1024)) FROM @userId for xml path(‘‘)),1,1,‘‘)

RETURN @uidStr

END

 

以上是关于SQL server字符串分割成表-表分割为字符串的主要内容,如果未能解决你的问题,请参考以下文章

Sql Server 中将由逗号“,”分割的一个字符串转换为一个表集,并应用到 in 条件中

sql如何根据隔符分割字符串?

SQL Server自定义字符串分割函数——Split

SQL Server自定义字符串分割函数——Split

PCB MS SQL 将字符串分割为表变量(表值函数)

SQL Server用SPLIT函数分割字符串