|
|
|
|
公众号矩阵

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

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

作者:数据库技术分享社区来源:今日头条|2021-01-08 16:27

今天给大家分享四个在实际开发中,比较实用的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 

【编辑推荐】

  1. 深渊之刃-Greenplum数据库之拉链表的实现
  2. MySQL不会丢失数据的秘密,就藏在它的7种日志里
  3. MySQL表空间回收的正确姿势
  4. 鸿蒙Harmony 应用开发view-binding 插件,和findComponentById说再见
  5. API快速开发平台设计思考
【责任编辑:华轩 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+更多

数据湖与数据仓库的分析实践攻略

数据湖与数据仓库的分析实践攻略

助力现代化数据管理:数据湖与数据仓库的分析实践攻略
共3章 | 创世达人

1人订阅学习

云原生架构实践

云原生架构实践

新技术引领移动互联网进入急速赛道
共3章 | KaliArch

30人订阅学习

数据中心和VPDN网络建设案例

数据中心和VPDN网络建设案例

漫画+案例
共20章 | 捷哥CCIE

209人订阅学习

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO官微