当前位置:主页 > 查看内容

数据库:分享四个实用的SQL Server脚本函数,欢迎收藏

发布时间:2021-04-16 00:00| 位朋友查看

简介:今天给大家分享四个在实际开发中,比较实用的SQL Server脚本函数,希望对大家能有所帮助! 1、字符串指定字符分割为list --字符串指定字符分割为list CREATE FUNCTION [dbo].[splitl]( @String VARCHAR ( MAX ), @Delimiter VARCHAR ( MAX ) ) RETURNS @tempt……

今天给大家分享四个在实际开发中,比较实用的SQL Server脚本函数,希望对大家能有所帮助!

1、字符串指定字符分割为list

  1. -- 字符串指定字符分割为list 
  2. CREATE FUNCTION [dbo].[splitl] ( 
  3.     @String VARCHAR(MAX), 
  4.     @Delimiter VARCHAR(MAX
  5. RETURNS @temptable TABLE (items VARCHAR(MAX)) AS 
  6. BEGIN 
  7.     DECLARE @idx INT=1 
  8.     DECLARE @slice VARCHAR(MAX)  
  9.     IF LEN(@String) < 1 OR LEN(ISNULL(@String,'')) = 0 
  10.         RETURN 
  11.     WHILE @idx != 0 
  12.     BEGIN 
  13.         SET @idx = CHARINDEX(@Delimiter,@String) 
  14.         IF @idx != 0 
  15.             SET @slice = LEFT(@String,@idx - 1) 
  16.         ELSE 
  17.             SET @slice = @String 
  18.         IF LEN(@slice) > 0 
  19.             INSERT INTO @temptable(items) VALUES(@slice) 
  20.         SET @String = RIGHT (@String, LEN(@String) - @idx) 
  21.         IF LEN(@String) = 0 
  22.             BREAK 
  23.     END 
  24.     RETURN 
  25. END 
  26. GO 
  27. -- 调用方式  
  28. SELECT * FROM dbo.splitl('aaa|bbb|ccc','|'

2、数字去掉末尾的0

  1. -- 数字去掉末尾的0 
  2. CREATE function [dbo].[ClearZero](@inValue varchar(50)) 
  3. returns varchar(50) 
  4. as 
  5. begin 
  6. declare @returnValue varchar(20) 
  7. if(@inValue=''
  8.    set @returnValue='' --空的时候为空 
  9. else if (charindex('.',@inValue) ='0'
  10.    set @returnValue=@inValue --针对不含小数点的 
  11. else if ( substring(reverse(@inValue),patindex('%[^0]%',reverse(@inValue)),1)='.'
  12.           set @returnValue = 
  13.             left(@inValue,len(@inValue)-patindex('%[^0]%',reverse(@inValue)))  
  14.             --针对小数点后全是0的 
  15.       else 
  16.           set @returnValue =left(@inValue,len(@inValue)-  
  17.                                  patindex('%[^0]%.%',reverse(@inValue))+1) --其他任何情形 
  18. return @returnValue 
  19. end 
  20. --调用示例 
  21. SELECT dbo.ClearZero(258.250300) 

3、创建表、视图、函数、存储过程判断是否存在

  1. /*判断函数/方法是否存在,若存在则删除函数/方法*/ 
  2. IF EXISTS (SELECT * FROM dbo.sysobjects WHERE name = 'Func_Name')  
  3. DROP FUNCTION Func_Name; 
  4. GO 
  5. --创建函数/方法 
  6. CREATE FUNCTION Func_Name 
  7.     @a INT 
  8. RETURN INT 
  9. AS 
  10. BEGIN 
  11. --coding 
  12. END 
  13. GO 
  14. /*判断存储过程是否存在,若存在则删除存储过程*/ 
  15. IF EXISTS (OBJECT_NAME('Proc_Name','P'IS NOT NULL DROP PROC Proc_Name; 
  16. GO 
  17. --创建存储过程 
  18. CREATE PROC Proc_Name 
  19. AS SELECT * FROM Table_Name 
  20. GO 
  21. /*判断数据表是否存在,若存在则删除数据表*/ 
  22. IF EXISTS (SELECT * FROM dbo.sysobjects WHERE name = 'Table_Name')  
  23. DROP VIEW Table_Name; 
  24. GO 
  25. --创建数据表 
  26. CREATE TABLE Table_Name 
  27.     Id INT PRIMARY KEY NOT NULL 
  28. /*判断视图是否存在,若存在则删除视图*/ 
  29. IF EXISTS (SELECT * FROM sys.views WHERE name = 'View_Name')  
  30. DROP VIEW View_Name  
  31. GO 
  32. --创建视图 
  33. CREATE VIEW View_Name AS 
  34.     SELECT SELECT * FROM table_name 
  35. GO 

4、金额转换为大写

  1. /* 
  2.     说明:数字金额转中文金额 
  3.     示例:187.4 转成 壹佰捌拾柒圆肆角整 
  4. */ 
  5.  
  6. CREATE FUNCTION [dbo].[CNumeric](@num numeric(14,2)) 
  7.     returns nvarchar(100) 
  8. BEGIN 
  9.     Declare @n_data nvarchar(20),@c_data nvarchar(100),@n_str nvarchar(10),@i int 
  10.     Set @n_data=right(space(14)+cast(cast(abs(@num*100) as bigintas nvarchar(20)),14) 
  11.     Set @c_data='' 
  12.     Set @i=1 
  13.  
  14.     WHILE @i<=14 
  15.     Begin 
  16.         set @n_str=substring(@n_data,@i,1) 
  17.         if @n_str<>'' 
  18.         begin 
  19.         IF not ((SUBSTRING(@n_data,@i,2)= '00'or 
  20.         ((@n_str= '0'and ((@i=4) or (@i=8) or (@i=12) or (@i=14)))) 
  21.         SET @c_data=@c_data+SUBSTRING( N'零壹贰叁肆伍陆柒捌玖',CAST(@n_str AS int)+1,1) 
  22.         IF not ((@n_str= '0'and (@i <> 4) and (@i <> 8) and (@i <> 12)) 
  23.         SET @c_data=@c_data+SUBSTRING( N'仟佰拾亿仟佰拾万仟佰拾圆角分',@i,1) 
  24.         IF SUBSTRING(@c_data,LEN(@c_data)-1,2)= N'亿万' 
  25.         SET @c_data=SUBSTRING(@c_data,1,LEN(@c_data)-1) 
  26.         END 
  27.         SET @i=@i+1 
  28.     END 
  29.     IF @num <0 
  30.         SET @c_data= '(负数)'+@c_data 
  31.     IF @num=0 
  32.         SET @c_data= '零圆' 
  33.     IF @n_str= '0' 
  34.         SET @c_data=@c_data+ '整' 
  35.  
  36.     RETURN(@c_data) 
  37. END 

本文转载自网络,原文链接:https://www.toutiao.com/i6913505104188408331/
本站部分内容转载于网络,版权归原作者所有,转载之目的在于传播更多优秀技术内容,如有侵权请联系QQ/微信:153890879删除,谢谢!

推荐图文


随机推荐