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

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

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

[[374709]]

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 

 

 

责任编辑:华轩 来源: 今日头条
相关推荐

2022-07-30 07:50:40

数据库字段存储

2011-04-01 10:26:28

SQL Server 数据库镜像

2020-12-18 09:10:36

数据库SQL Server存储空间

2019-08-12 08:47:14

脚本语言数据库MySQL

2019-10-16 00:37:36

Oracle数据库游标数

2020-10-29 08:35:06

Pandas函数Python

2011-03-28 17:12:36

SQL Server数转换服务

2024-02-23 18:17:57

Python脚本开发

2023-10-26 07:05:58

MySQL数据库

2019-10-31 08:22:39

shell脚本Linux

2011-09-21 14:00:34

SQL Server

2019-07-17 07:07:54

MySQL数据库索引

2020-12-11 07:00:42

MySQL数据库备份脚本

2009-03-03 11:41:14

数据库表表分区

2021-10-26 22:43:05

数据库安全存储

2015-03-30 12:54:55

SQL ServerSQL Server

2010-07-01 11:49:13

SQL Server

2010-07-15 17:28:50

SQL Server

2021-08-26 15:27:29

数据库服务器数据库服务器

2011-03-21 10:26:10

SQL Server视图管理
点赞
收藏

51CTO技术栈公众号