Sql中分隔字串-->查询-->组合字串
最近在工作遇到一个数据库查询的问题,大概如下:表Table1中有字段No和Title,每一个No对应一个Title,表Table2中有NoAll字段,NoAll字段的value是No的组合,以逗号隔开,如"111,222,333",现在要查询Table2,根据NoAll将其中的每一个No所对应的Title查询出来也以逗号分隔显示,如:"oec2003,oec2004,oec2004"。表定义如下:
CREATE TABLE Table1
(
No VARCHAR(5),
Title VARCHAR(20)
)
CREATE TABLE Table2
(
NoAll VARCHAR(100)
)
INSERT INTO Table1 VALUES('111','oec2003')
INSERT INTO Table1 VALUES('222','oec2004')
INSERT INTO Table1 VALUES('333','oec2005')
INSERT INTO Table2 VALUES('111,222,333')
因为NoAll是用逗号分隔的,所以要查询其中的每一个No就要将NoAll进行拆分,就想到了写一个split函数,如下:
CREATE FUNCTION Split
(
@SourceSql varchar(8000),
@StrSeprate varchar(10)
)
RETURNS @temp TABLE(F1 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
将NoAll拆分了后返回的是一个Table,Table中的每一行是一个No值,要查出每个No对应的Title就要遍历这个Table,首先想到的就是使用游标,在这里我也是将游标写在了一个函数里,如下:
CREATE FUNCTION GetTitle(@NoAll NVARCHAR(2000))
RETURNS NVARCHAR(2000)
AS
BEGIN
DECLARE @result VARCHAR(2000)
SET @result=''
DECLARE getTitle CURSOR
FOR
SELECT * FROM split(@NoAll,',')
OPEN getTitle
DECLARE @No SYSNAME
FETCH FROM getTitle INTO @No
WHILE @@fetch_status=0
BEGIN
SET @result=@result+(SELECT Title FROM Table1 WHERE No=@No)+','
FETCH FROM getTitle INTO @No
END
CLOSE getTitle
SET @result= substring(@result,0,len(@result))
DEALLOCATE getTitle
RETURN @result
END
最后执行下面语句出想要的结果,如下:
SELECT
NoAll,
dbo.GetTitle(No) AS TitleAll
FROM
Table2
我这个方法只是将功能实现了,肯定还有更好的方法,欢迎大家讨论
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗