码迷,mamicode.com
首页 > 数据库 > 详细

sql习题

时间:2017-08-25 01:15:43      阅读:174      评论:0      收藏:0      [点我收藏+]

标签:ring   returns   upd   tran   exists   declare   case   forward   方式   

/* 转换为
100-5 0100-00005
1-998 0001-00998
12-1589 0012-01589
*/
IF EXISTS(SELECT * FROM sys.objects WHERE name=‘Fun_CombineTransfer‘)
DROP FUNCTION dbo.Fun_CombineTransfer
GO
CREATE FUNCTION Fun_CombineTransfer(@aaa NVARCHAR(20))
RETURNS NVARCHAR(20)
AS
BEGIN
DECLARE @sReturn NVARCHAR(20)=‘‘
DECLARE @ForwardNum INT
DECLARE @AfferNum INT
DECLARE @ForwardChar NVARCHAR(20)=‘‘
DECLARE @AfferChar NVARCHAR(20)=‘‘
SET @ForwardNum=(SELECT CHARINDEX(‘-‘,@aaa)-1)
SET @ForwardChar=( CASE @ForwardNum WHEN 1 THEN ‘000‘WHEN 2 THEN ‘00‘WHEN 3 THEN ‘0‘WHEN 4 THEN ‘‘END)
SET @AfferNum=(SELECT CHARINDEX(‘-‘,REVERSE(@aaa))-1)
SET @AfferChar=(CASE @AfferNum WHEN 1 THEN ‘0000‘WHEN 2 THEN ‘000‘WHEN 3 THEN ‘00‘WHEN 4 THEN ‘0‘END)
SET @sReturn=@ForwardChar+(SELECT SUBSTRING(@aaa,1,CHARINDEX(‘-‘,@aaa)))+@AfferChar+
(SELECT REVERSE(SUBSTRING(REVERSE(@aaa),1,(CHARINDEX(‘-‘,REVERSE(@aaa))-1))))
RETURN @sReturn
END

第二种方式

UPDATE #temp SET aaa=RIGHT(‘000‘+SUBSTRING(aaa,1,CHARINDEX(‘-‘,aaa)-1),4)+‘-‘+
RIGHT(‘0000‘+SUBSTRING(aaa,CHARINDEX(‘-‘,aaa)+1,LEN(aaa)),5)

sql习题

标签:ring   returns   upd   tran   exists   declare   case   forward   方式   

原文地址:http://www.cnblogs.com/yachao1120/p/7425936.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!