正文
sql server 字符串拆分
小程序:扫一扫查出行
【扫一扫了解最新限行尾号】
复制小程序
【扫一扫了解最新限行尾号】
复制小程序
最近项目调取存储的时候直接传入string 作为in的查询范围,结果报错了,深思之后才发现,数据库对于传进来的String,并不是我们想的直接可以作为参数,而是作为一个整体,而in是需要一个类似array或者list的参数,为此,需要一个拆分string的sql 函数,还好之前的前辈留下了可以用的,稍微修改一下就可以了,下面来看看这个函数
FUNCTION f_split
(
-- Add the parameters for the function here
@SourceStr VARCHAR(max),@SeprateStr VARCHAR(10)
)
RETURNS @temp TABLE (a VARCHAR(1000))
AS
BEGIN
DECLARE @i INT
SET @SourceStr = RTRIM(LTRIM(@SourceStr))--去除空格
SET @i=CHARINDEX(@SeprateStr,@SourceStr)
WHILE @i>=1
BEGIN
INSERT @temp
( a )
VALUES ( LEFT(@SourceStr,@i-1) -- a - varchar(1000)
)
SET @SourceStr = SUBSTRING(@SourceStr,@i+1,LEN(@SourceStr)-@i)
SET @i=CHARINDEX(@SeprateStr,@SourceStr)
END
RETURN
END
GO
应该写的很清晰了,就不细说了,欢迎大家指导