首页 新闻 论坛 群组 Blog 文档 下载 读书 Tag 网摘 搜索 .NET Java 游戏 视频 人才 外包 培训 数据库 书店 程序员
中国软件网
欢迎您:游客 | 登录 注册 帮助
  • [向SQL提问]【原创】人民币小写金额转大写 [已结贴,结贴人:dobear_0922]
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • dobear_0922
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    • 揭贴率:
    发表于:2008-06-12 13:51:18 楼主
    SQL code
    -- ==================================================================== -- Title: 人民币小写金额转大写 -- Author: dobear Mail(MSN): dobear_0922@hotmail.com -- Environment: Vista + SQL2005 -- Date: 2008-06-12 -- Remark: dobear原创,转载请注明出处,有问题请发Mail告之 -- ==================================================================== IF OBJECT_ID('fn_GetFormatMoney', N'FN') IS NOT NULL DROP FUNCTION fn_GetFormatMoney GO CREATE FUNCTION dbo.fn_GetFormatMoney (@money numeric(14,2)) RETURNS NVARCHAR(32) AS BEGIN DECLARE @money_num NVARCHAR(20) --存储金额的字符形式 , @money_chn NVARCHAR(32) --存储金额的中文大写形式 , @n_chn NVARCHAR(1), @i INT --临时变量 SELECT @money_chn=CASE WHEN @money>=0 THEN '' ELSE '(负)' END , @money=ABS(@money) , @money_num=STUFF(STR(@money, 15, 2), 13, 1, '') --加前置空格补齐到14位(去掉小数点) , @i=PATINDEX('%[1-9]%', @money_num) --找到金额最高位 WHILE @i>=1 and @i<=14 BEGIN SET @n_chn=SUBSTRING(@money_num, @i, 1) IF @n_chn<>'0' or (SUBSTRING(@money_num,@i+1,1)<>'0' and @i not in(4, 8, 12, 14)) --转换阿拉伯数字为中文大写形式 SET @money_chn=@money_chn+SUBSTRING('零壹贰叁肆伍陆柒捌玖', @n_chn+1, 1) IF @n_chn<>'0' or @i in(4, 8, 12) --添加中文单位 SET @money_chn=@money_chn+SUBSTRING('仟佰拾亿仟佰拾万仟佰拾圆角分',@i,1) SET @i=@i+1 END SET @money_chn=REPLACE(@money_chn, '亿万', '亿') --当金额为X亿零万时去掉万 IF @money=0 SET @money_chn='零圆整' --当金额为零时返回'零圆整' IF @n_chn='0' SET @money_chn=@money_chn+'' --当金额末尾为零分时以'整'结尾 RETURN @money_chn --返回大写金额 END GO

    功能测试:
    SQL code
    GO CREATE TABLE tb_money(id INT IDENTITY(1,1) PRIMARY KEY, m NUMERIC(14,2)) INSERT tb_money SELECT 0 UNION ALL SELECT 0.01 UNION ALL SELECT 0.2 UNION ALL SELECT 0.35 UNION ALL SELECT 230 UNION ALL SELECT 10000.2 UNION ALL SELECT 10020.3 UNION ALL SELECT 10300.45 UNION ALL SELECT -10304.07 UNION ALL SELECT 30210020 UNION ALL SELECT -3020000 UNION ALL SELECT 3020400 UNION ALL SELECT 302040000000 UNION ALL SELECT 302004000000.1 select m as '小写金额', dbo.fn_GetFormatMoney(m) as '大写金额' from tb_money /* 小写金额 大写金额 --------------------------------------- -------------------------------- 0.00 零圆整 0.01 壹分 0.20 贰角整 0.35 叁角伍分 230.00 贰佰叁拾圆整 10000.20 壹万圆贰角整 10020.30 壹万零贰拾圆叁角整 10300.45 壹万零叁佰圆肆角伍分 -10304.07 (负)壹万零叁佰零肆圆零柒分 30210020.00 叁仟零贰拾壹万零贰拾圆整 -3020000.00 (负)叁佰零贰万圆整 3020400.00 叁佰零贰万零肆佰圆整 302040000000.00 叁仟零贰拾亿肆仟万圆整 302004000000.10 叁仟零贰拾亿零肆佰万圆壹角整 (14 row(s) affected) */ DROP TABLE tb_money
    300  修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • dobear_0922
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    发表于:2008-06-12 13:51:331楼 得分:0
    沙发,,,
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • libin_ftsafe
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    • 5

    发表于:2008-06-12 13:54:282楼 得分:12
    呵呵
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • libin_ftsafe
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    • 5

    发表于:2008-06-12 13:55:003楼 得分:0
    路过
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • libin_ftsafe
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    • 5

    发表于:2008-06-12 13:55:124楼 得分:0
    连三
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • ranzj
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    发表于:2008-06-12 13:56:395楼 得分:12
    问:比 money 类型上限值大的数值怎么办?
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • dobear_0922
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    发表于:2008-06-12 13:58:066楼 得分:0
    引用 5 楼 ranzj 的回复:
    问:比 money 类型上限值大的数值怎么办?


    暂时只支持千亿,精度为分,,,
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • liangCK
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    • 2

    发表于:2008-06-12 14:00:087楼 得分:12
    支持.
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • happyflystone
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    • 4

      5

    发表于:2008-06-12 14:01:408楼 得分:12
    飘过
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • lfywy
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    发表于:2008-06-12 14:03:029楼 得分:12
    看看!不错!MARK!
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • dobear_0922
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    发表于:2008-06-12 14:03:4810楼 得分:0
    欢迎测试,大家帮忙看看有没有更好的算法,,,
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • water792
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    发表于:2008-06-12 14:06:0511楼 得分:12
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • wzy_love_sly
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    发表于:2008-06-12 14:07:2412楼 得分:12
    飘~~
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • wzy_love_sly
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    发表于:2008-06-12 14:08:3313楼 得分:0
    支持
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • wzy_love_sly
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    发表于:2008-06-12 14:09:0914楼 得分:0
    学习
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • liangCK
    • 等级:
    • 可用分等级:
    • 总技术分:
    • 总技术分排名:
    • 2

    发表于:2008-06-12 14:12:3815楼 得分:0
    SQL code
    这是以前收藏的.. exec ConvertToUpperCase 1000600200100.56,@a output --将123456789.56转换成大写金额 select @a --在QA中查看效果 create procedure ConvertToUpperCase (@mExpense Money,@sRetUpperMoney varchar(50) OutPut) as begin declare @sExpense varchar(20),@sLittle varchar(4),@sFixed varchar(15) declare @nDot Integer,@nLenAll Integer,@sUpperMoney varchar(30),@nStep Integer declare @cChar char(1),@sUpperNumbers varchar(30),@sNumber char(2),@sTemp varchar(50) declare @sZero char(2),@nIsZeroLast Integer,@sth varchar(10),@nFixed Integer declare @sMoney char(2) if @mExpense=0 begin select @sRetUpperMoney='零元' return end if @mExpense<0 begin select @sMoney='' select @mExpense=abs(@mExpense) end else select @sMoney='' select @sUpperMoney = '万仟佰拾亿仟佰拾万仟佰拾元' --加大范围 select @sUpperNumbers= '玖捌柒陆伍肆叁贰壹零' select @sZero = '' select @sExpense = convert(varchar(20),@mExpense) select @nDot = CharIndex('.',@sExpense) select @nLenAll = Len(@sExpense) if @nDot > 0 begin select @sFixed = substring(@sExpense,1,@nDot -1) select @sLittle = substring(@sExpense,@nDot + 1,@nLenAll - @nDot) end else select @sFixed = @sExpense select @nFixed = Len(@sFixed) select @nStep = @nFixed select @sTemp = '' select @nIsZeroLast = 0 if @sFixed <> '0' while @nStep > 0 begin --while @nStep > 0 select @cChar = substring(@sFixed,@nStep,1) select @sNumber = substring(@sUpperNumbers,10 - convert(int,@cChar),1) select @sth = substring(@sUpperMoney,len(@sUpperMoney) - (Len(@sFixed) - @nStep),1) if @cChar <> '0' begin --if @cChar <> '0' if @nIsZeroLast = 0 select @sTemp = @sNumber + @sth + @sTemp if @nIsZeroLast = 1 begin select @sTemp = @sNumber + @sth + @sZero + @sTemp select @nIsZeroLast = 0 end if @nIsZeroLast = 2 begin select @sTemp = @sNumber + @sth + @sTemp select @nIsZeroLast = 0 end end --if @cChar <> '0' else --@cChar = '0' begin if @nIsZeroLast <> 2 begin --@nIsZeroLast <> 2 if (@sth = '') or (@sth = '亿') or (@sth = '') begin if @nIsZeroLast = 1 begin select @sTemp = @sth + @sZero + @sTemp if substring(@sTemp,1,3)='亿万零' --修改 select @sTemp=stuff(@sTemp,1,3,'亿零') select @nIsZeroLast = 2 end else begin select @sTemp = @sth + @sTemp if @sTemp='万元' --修改 select @sTemp='