TSql Work with comma

tsql因为没有数组的概念,那么如何把一批数据传给数据库引擎让它一次性处理完呢。那么我们可以在客户端把数据用逗号串联起来,然后把这些数据作为NVARCHAR(MAX)传给数据库,然后在数据库分割这个用逗号分隔的字符串。

先不谈怎么分割这个有逗号分隔的字符串,看看怎么把数据库中的记录用逗号分隔检索出来,如下有一种方式:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
DECLARE @vv AS NVARCHAR(MAX)
 
;With employees(ID, Name) AS(
    SELECT 1, 'Eric' UNION ALL
    SELECT 2, 'Petter' UNION ALL
    SELECT 3, 'Wang' UNION ALL
    SELECT 4, 'Jeff' UNION ALL
    SELECT 5, NULL )
 
SELECT @vv = COALESCE(@vv + ', ', '') + CAST(Name AS NVARCHAR(10))
FROM employees
WHERE Name IS NOT NULL
 
SELECT @vv
1
结果如下:
1
Eric, Petter, Wang, Jeff
1
现在来看看如何分割字符串(其实就是分割CSV字符串):
1
第一种方式,找到逗号所在位置,然后提出逗号前的部分,然后循环,处理第二个逗号。。。代码如下,很简单:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
CREATE FUNCTION [dbo].[parseCsv1](@chars NVARCHAR(MAX))
RETURNS @tv TABLE(value NVARCHAR(50))
AS
BEGIN
    DECLARE @spIndex AS INT
    DECLARE @varItem AS NVARCHAR(MAX)
     
    SET @chars = @chars + ','
     
    WHILE PATINDEX('%,%', @chars) <> 0
    BEGIN
        SET @spIndex = PATINDEX('%,%', @chars)
        SET @varItem = LEFT(@chars, @spIndex-1)
        INSERT @tv VALUES(@varItem)
         
        SET @chars = STUFF(@chars, 1, @spIndex, '')       
    END   
     
    RETURN
END
1
第二种方式,使用集合的方式来处理,代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
CREATE FUNCTION parseCsv2(@varChars NVARCHAR(MAX))
RETURNS @tv TABLE(value NVARCHAR(50))
AS
BEGIN
    SET @varChars = ',' + @varChars + ','
 
    ;WITH cte1 AS(
        SELECT N sI
        FROM dbo.Number
        WHERE N <= LEN(@varChars)AND SUBSTRING(@varChars, N, 1) =','),
         
    cte2 (indStart, indEnd) AS(SELECT c.* , c2.* FROM cte1 c CROSS APPLY(
        SELECT TOP 1 * FROM cte1
        WHERE si > c.si) as c2)
 
    INSERT INTO @tv
    SELECT V
    FROM(
        SELECT *, RTRIM(LTRIM(SUBSTRING(@varChars, indStart+1, indEnd -indStart-1))) AS v
        FROM cte2
    ) AS d1 WHERE v <> ''
     
    RETURN
END

这种方式完全没有使用到循环,采用了集合的方式来处理字符串。

posted @   冯小诺  阅读(386)  评论(2编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示