--示例數(shù)據(jù)
CREATE TABLE tb(ID int,col varchar(50))
INSERT tb SELECT 1,'1,2,3,4'
UNION ALL SELECT 1,'1,3,4'
UNION ALL SELECT 1,'1,4'
UNION ALL SELECT 2,'11,3,4'
UNION ALL SELECT 2,'1,33,4'
UNION ALL SELECT 3,'1,3,4'
GO
--1. 字符串并集處理函數(shù)
CREATE FUNCTION dbo.f_mergSTR(@ID int)
RETURNS varchar(50)
AS
BEGIN
?DECLARE @t TABLE(ID int identity,b bit)
?--分拆處理輔助表,由于列col的最大寬度為50,所以只需要1到50的分拆輔助記錄
?INSERT @t(b) SELECT TOP 50 0
?FROM syscolumns
?DECLARE @r varchar(50)
?SET @r=''
?SELECT @r=@r+','+s
?FROM(
??SELECT s=SUBSTRING(a.col,b.ID,CHARINDEX(',',a.col+',',b.ID)-b.ID)
??FROM tb a,@t b
??WHERE
a.ID=@ID
???AND b.ID<=LEN(a.col)
???AND SUBSTRING(','+a.col,b.ID,1)=','
??GROUP BY SUBSTRING(a.col,b.ID,CHARINDEX(',',a.col+',',b.ID)-b.ID)
?)a ORDER BY s
?RETURN(STUFF(@r,1,1,''))
END
GO
--調(diào)用用戶定義實(shí)現(xiàn)交并集查詢
SELECT ID,col=dbo.f_mergSTR(ID)
FROM tb
GROUP BY ID
GO
/*================================================================*/
--2. 字符串交集處理函數(shù)
CREATE FUNCTION dbo.f_mergSTR(@ID int)
RETURNS varchar(50)
AS
BEGIN
?DECLARE @t TABLE(ID int identity,b bit)
?--分拆處理輔助表,由于列col的最大寬度為50,所以只需要1到50的分拆輔助記錄
?INSERT @t(b) SELECT TOP 50 0
?FROM syscolumns
?DECLARE @r varchar(50)
?SET @r=''
?SELECT @r=@r+','+s
?FROM(
??SELECT s=SUBSTRING(a.col,b.ID,CHARINDEX(',',a.col+',',b.ID)-b.ID)
??FROM tb a,@t b
??WHERE
a.ID=@ID
???AND b.ID<=LEN(a.col)
???AND SUBSTRING(','+a.col,b.ID,1)=','
??GROUP BY SUBSTRING(a.col,b.ID,CHARINDEX(',',a.col+',',b.ID)-b.ID)
??HAVING COUNT(*)=(SELECT COUNT(*) FROM tb WHERE
ID=@ID))a
?RETURN(STUFF(@r,1,1,''))
END
GO
--調(diào)用用戶定義實(shí)現(xiàn)交交集查詢
SELECT ID,col=dbo.f_mergStr(ID)
FROM tb
GROUP BY ID
GO
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元

