ERDS网校 - ERDS企业自主信息化培训,交流

查看: 301|回复: 0

小写转大写语法

[复制链接]

37

主题

42

帖子

144

积分

注册会员

Rank: 2

积分
144
发表于 2015-11-27 14:00:23 | 显示全部楼层 |阅读模式
本帖最后由 cherish 于 2015-11-27 14:00 编辑

先建立一个函数dbo.L2U
create FUNCTION dbo.L2U(@n_LowerMoney numeric(15,2),@v_TransType int)      
RETURNS VARCHAR(200) AS      
BEGIN      
Declare @v_LowerStr VARCHAR(200) -- 小写金额      
Declare @v_UpperPart VARCHAR(200)      
Declare @v_UpperStr VARCHAR(200) -- 大写金额     
Declare @i_I int      
      
set @v_LowerStr = LTRIM(RTRIM(ROUND(@n_LowerMoney,2))) --四舍五入为指定的精度并删除数据左右空格     
set @i_I = 1      
set @v_UpperStr = ''      
      
while ( @i_I <= len(@v_LowerStr))      
begin      
select @v_UpperPart = case substring(@v_LowerStr,len(@v_LowerStr) - @i_I + 1,1)      
WHEN '.' THEN '元'      
WHEN '0' THEN '零'      
WHEN '1' THEN '壹'      
WHEN '2' THEN '贰'      
WHEN '3' THEN '叁'      
WHEN '4' THEN '肆'      
WHEN '5' THEN '伍'      
WHEN '6' THEN '陆'      
WHEN '7' THEN '柒'      
WHEN '8' THEN '捌'      
WHEN '9' THEN '玖'      
END      
+      
case @i_I      
WHEN 1 THEN '分'      
WHEN 2 THEN '角'      
WHEN 3 THEN ''      
WHEN 4 THEN ''      
WHEN 5 THEN '拾'      
WHEN 6 THEN '佰'      
WHEN 7 THEN '仟'      
WHEN 8 THEN '万'      
WHEN 9 THEN '拾'      
WHEN 10 THEN '佰'      
WHEN 11 THEN '仟'      
WHEN 12 THEN '亿'      
WHEN 13 THEN '拾'      
WHEN 14 THEN '佰'      
WHEN 15 THEN '仟'      
WHEN 16 THEN '万'      
ELSE ''      
END      
set @v_UpperStr = @v_UpperPart + @v_UpperStr      
set @i_I = @i_I + 1      
end      
      
if ( 0 = @v_TransType)      
begin      
set @v_UpperStr = REPLACE(@v_UpperStr,'零拾','零')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零佰','零')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零仟','零')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零零零','零')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零零','零')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零角零分','整')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零分','整')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零角','零')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零亿零万零元','亿元')      
set @v_UpperStr = REPLACE(@v_UpperStr,'亿零万零元','亿元')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零亿零万','亿')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零万零元','万元')      
set @v_UpperStr = REPLACE(@v_UpperStr,'万零元','万元')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零亿','亿')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零万','万')      
set @v_UpperStr = REPLACE(@v_UpperStr,'零零','零')      
end  
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|ERDS网校   点击这里给我发消息

快速回复 返回顶部 返回列表