sqlserver Split 开放写法有兴趣的学习一下

sqlserver Split 开放写法有兴趣的学习一下,第1张

概述USE [MssDb]GO/****** Object: UserDefinedFunction [dbo].[F_SQLSERVER_SPLIT] Script Date: 07/19/2016 09:56:15 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGO-- ==========================
USE [MssDb]GO/****** Object:  UserdefinedFunction [dbo].[F_sqlSERVER_SPliT]    Script Date: 07/19/2016 09:56:15 ******/SET ANSI_NulLS ONGOSET QUOTED_IDENTIFIER ONGO-- =============================================-- Author:		yanghui-- ALTER date: 2012-5-18-- Description:	<split功能>-- =============================================ALTER FUNCTION [dbo].[F_sqlSERVER_SPliT](@Long_str NVARCHAR(MAX),@split_str NVARCHAR(100))    RETURNS  @tmp table(            ID          inT     IDENTITY PRIMARY KEY,short_str   NVARCHAR(MAX)    )    AS   BEGIN       DECLARE @short_str NVARCHAR(MAX),@split_str_length int,@split_str_position_Begin int    SET @split_str_length = LEN(@split_str)     SET @Long_str=REPLACE(REPLACE(@Long_str,CHAR(10),''),CHAR(13),'')    IF CHARINDEX(@split_str,@Long_str)=1          SET @Long_str=STUFF(@Long_str,1,@split_str_length,@Long_str)=0        INSERT INTO @tmp SELECT @Long_str     ELSE        BEGIN            WHILE 1>0                    BEGIN                       SET @split_str_position_Begin = CHARINDEX(@split_str,@Long_str)                    SET @short_str=left(@Long_str,@split_str_position_Begin-1)                     IF @short_str<>'' INSERT INTO @tmp SELECT @short_str                      SET @Long_str=STUFF(@Long_str,@split_str_position_Begin+@split_str_length-1,'')                    SET @split_str_position_Begin = CHARINDEX(@split_str,@Long_str)                    IF @split_str_position_Begin=0                     BEGIN                        IF LTRIM(@Long_str)<>''                            INSERT INTO @tmp SELECT @Long_str                         BREAK                    END                END                   END    RETURN     END

另外关于sqlserver 合并与拆分我在多说几句,大多用到Split 函数的时候基本需要拆分处理,以上是我的写法一下是大神级别做法,供参考

原始数据如图所示


SELECT *FROM  dbo.aaa AS t01 CROSS apply dbo.Split(t01.name,',') AS t02
上面是采用split语句拆分处理,拆分之后数据显示如下


合并语句

SELECT     ID,stuff((        SELECT             ','+CLASS         FROM dbo.bbb AS tb01 where tb01.ID=tb02.ID        FOR xml PATH('')),1,'') AS classList  FROM  dbo.bbb AS tb02  GROUP BY ID
合并之后处理结果如下

总结

以上是内存溢出为你收集整理的sqlserver Split 开放写法有兴趣的学习一下全部内容,希望文章能够帮你解决sqlserver Split 开放写法有兴趣的学习一下所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1170884.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存