SQL——自定义的fn_Split函数


--1. 创建fn_Split函数. ( 切分字符串, 返回一个列名为id的表 )  

  1. if exists(select * from dbo.sysobjects where id = object_id('fn_Split'and (type = 'FN' or type = 'TF' or type='IF'))  
  2.     DROP FUNCTION fn_Split  
  3. GO  
  4.   
  5. CREATE FUNCTION [dbo].[fn_Split]  
  6. (  
  7.     @str    VARCHAR(MAX),  
  8.     @separator  VARCHAR(10)  
  9. )  
  10. RETURNS TABLE  
  11. AS  
  12.     RETURN  
  13.     (   --Example:  SELECT id FROM fn_Split('a,b,d,c',',')   
  14.         SELECT B.id  
  15.         FROM   (  
  16.                    SELECT [value] = CONVERT(XML, '<v>' + REPLACE(@str, @separator, '</v><v>') + '</v>')  
  17.                ) A  
  18.                OUTER APPLY(  
  19.             SELECT id = N.v.value('.''varchar(100)')  
  20.             FROM   A.[value].nodes('/v') N(v)  
  21.         ) B  
  22.     )  
  23. GO  

相关内容