2000多变一

CREATE TABLE tb ( id INT, value VARCHAR(10) ) 
INSERT  INTO tb 
VALUES  ( 1, 'aa' ) 
INSERT  INTO tb 
VALUES  ( 1, 'bb' ) 
INSERT  INTO tb 
VALUES  ( 2, 'aaa' ) 
INSERT  INTO tb 
VALUES  ( 2, 'bbb' ) 
INSERT  INTO tb 
VALUES  ( 2, 'ccc' ) 
go 
 
CREATE FUNCTION dbo.f_str ( @id INT ) 
RETURNS VARCHAR(100
AS  
    BEGIN 
        DECLARE @str VARCHAR(1000
        SET @str = '' 
        SELECT  @str = @str + ',' + CAST(value AS VARCHAR) 
        FROM    tb 
        WHERE   id = @id 
        SET @str = RIGHT(@str, LEN(@str) - 1
        RETURN @str 
    END 
go 
 
--调用函数 
SELECT  id , 
        value = dbo.f_str(id) 
FROM    tb 
GROUP BY id 
 
DROP FUNCTION dbo.f_str 
DROP TABLE tb 
 
 
 
posted @   qanholas  阅读(202)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 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 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
点击右上角即可分享
微信分享提示