人民币小写金额转大写

--1、人民币小写金额转大写(第一版)

====================================================================

-- Title: 人民币小写金额转大写

-- Author: dobear        Mail(MSN): dobear_0922@hotmail.com

-- Environment: Vista + SQL2005

-- Date: 2008-06-12

-- Remark: dobear原创,转载请注明出处,有问题请发Mail告之

-- ====================================================================

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, '')    --加前置空格补齐到位(去掉小数点)

        , @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

--测试示例

select dbo.fn_getformatmoney(4545.44)

--运行结果

/*

肆仟伍佰肆拾伍圆肆角肆分

*/

 

--2、人民币小写金额转大写(第二版)

/*编写者:(博客天地www.inbaidu.com )

创建时间:

功能:小写金额转换成大写

参数:@LowerMoney 小写金额加上小数点最长可以保留位

输出:大写金额

简介:SQL版小写金额转换成大写金额(最多可以精确到小数点四位)

注: Decimal 数据类型最多可存储个数字

转载:请保留以上信息,谢谢!!!

********************************************************/

go

--创建函数

create function [dbo].[lowertoupper](@lowermoney decimal(38,4))

returns varchar(200)    --返回的大写金额的字符

as

begin

      declare @lowerstr  varchar(50)    --小写金额

      declare @upperstr  varchar(200)  --大写金额

      declare @uppertmp  varchar(15)    --大写金额的临时字符串

      declare @i          int            --递增量

      declare @lowerlen  int            --小写金额的总长度

 

      set @lowerstr = @lowermoney --把decimal型的值全部赋给字符串变量注:(赋值过去的话如在字符串变量中是显示.0000 因为小数位精确到四位,没有的话,它会自动补)

      set @lowerstr = replace(@lowerstr,'.','') --把小数点替换成空字符    --精确到小数点的四位角分厘毫

 

      set @lowerlen = len(@lowerstr) --获取小写金额的总长度(包括四个小数位)

      select @i = 1,@upperstr = '',@uppertmp = '' --设置默认初始值

 

      while @i <= @lowerlen         

          begin

            set @uppertmp = case

                                  when substring(@lowerstr,@lowerlen - @i + 1,1) = '0' and @i = 5 and(convert(int,right(@lowerstr,4)) = 0 or @lowerlen > 5) then '元'      --注:如果个位为的话,并且四位小数都是或者它的长度超过(也就是超过元),则为元

                                  --when substring(@lowerstr,@lowerlen - @i + 1,1) = '0' then ''

                                  else

                                      + case substring(@lowerstr,@lowerlen - @i + 1,1) --看当前位是数字几,就直接替换成汉字繁体大写

                                              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

                                              when 1      then '毫'

                                              when 2      then '厘'

                                              when 3      then '分'

                                              when 4      then '角'

                                              when 5      then '元'

                                              when 9      then '萬'

                                              when 13      then '亿'

                                              when 17      then '兆'

                                              when 21      then '京'

                                              when 25      then '垓'

                                              when 29      then '杼' 

                                              when 33      then '穰'

                                              when 37      then '沟' --decimal型最大长度是后面的就不用再考虑了

                                              else

                                                  + case @i%4

                                                          when 2 then '拾'      --拾10 14 18 22 26 30 34 38 …………

                                                          when 3 then '佰'      --佰11 15 19 23 27 31 35 39 …………

                                                          when 0 then '仟'      --仟12 16 20 24 28 32 36 40 …………

                                                      end

                                        end

                            end

            set @upperstr = isnull(@uppertmp,'') + isnull(@upperstr,'')

            set @i = @i + 1

          end

      if convert(int,right(@lowerstr,4)) = 0 set @upperstr = left(@upperstr,len(@upperstr)-8) + '整' --判断小数位数是不是都是,是就可以取整

      while patindex('%零[仟佰拾角分厘毫零]%',@upperstr) <> 0    --把零拾或零佰或零零变成一个零

          begin

            set @upperstr = stuff(@upperstr,patindex('%零[仟佰拾角分厘毫零]%',@upperstr),2,'零')

          end

      while patindex('%[沟穰杼垓京兆亿萬]零[沟穰杼垓京兆亿萬]%',@upperstr) <> 0 --把零萬或零亿的清空掉

          begin

            select @upperstr = stuff(@upperstr,patindex('%[沟穰杼垓京兆亿萬]零[沟穰杼垓京兆亿萬]%',@upperstr)+1,2,'')

          end

      while patindex('%[仟佰拾]零[沟穰杼垓京兆亿萬]%',@upperstr) <> 0 --把类似拾零萬或佰零萬或仟零萬中间的零清空掉

          begin

            select @upperstr = stuff(@upperstr,patindex('%[仟佰拾]零[沟穰杼垓京兆亿萬]%',@upperstr)+1,1,'')

          end

      if patindex('%_零[元]%',@upperstr) <> 0 --把类似拾零元或百零元中间的零清空掉

          begin

            select @upperstr = stuff(@upperstr,patindex('%_零[元]%',@upperstr) + 1,1,'')

  end

      else if (patindex('零[元]%',@upperstr) <> 0) and (convert(int,right(@lowerstr,4)) <> 0) --判断当前否是零元开头,并且后面的四个小数不为

              begin

          select @upperstr = stuff(@upperstr,patindex('零[元]%',@upperstr),2,'') --把零元清空掉

        end

      if right(@upperstr,1) = '零' set @upperstr = left(@upperstr,len(@upperstr)-1)      --如果最后一位是零也清空掉

      if @upperstr = '元整' set @upperstr = '零' + @upperstr                            --如果只是的话,就显示零元整

      return @upperstr      --返回大写金额

end 

 

--测试示例

Select dbo.LowerToUpper(120000000) --壹亿贰仟萬元整

Select dbo.LowerToUpper(102000000) --壹亿零贰佰萬元整

Select dbo.LowerToUpper(100200000) --壹亿零贰拾萬元整

Select dbo.LowerToUpper(100020000) --壹亿零贰萬元整

Select dbo.LowerToUpper(100002000) --壹亿贰仟元整

 

--运行结果

/*

壹亿贰仟萬元整

壹亿零贰佰萬元整

壹亿零贰拾萬元整

壹亿零贰萬元整

壹亿贰仟元整

*/

转载于:https://www.cnblogs.com/accumulater/p/6244571.html

内容概要:本文深入探讨了Kotlin语言在函数式编程和跨平台开发方面的特性和优势,结合详细的代码案例,展示了Kotlin的核心技巧和应用场景。文章首先介绍了高阶函数和Lambda表达式的使用,解释了它们如何简化集合操作和回调函数处理。接着,详细讲解了Kotlin Multiplatform(KMP)的实现方式,包括共享模块的创建和平台特定模块的配置,展示了如何通过共享业务逻辑代码提高开发效率。最后,文章总结了Kotlin在Android开发、跨平台移动开发、后端开发和Web开发中的应用场景,并展望了其未来发展趋势,指出Kotlin将继续在函数式编程和跨平台开发领域不断完善和发展。; 适合人群:对函数式编程和跨平台开发感兴趣的开发者,尤其是有一定编程基础的Kotlin初学者和中级开发者。; 使用场景及目标:①理解Kotlin中高阶函数和Lambda表达式的使用方法及其在实际开发中的应用场景;②掌握Kotlin Multiplatform的实现方式,能够在多个平台上共享业务逻辑代码,提高开发效率;③了解Kotlin在不同开发领域的应用场景,为选择合适的技术栈提供参考。; 其他说明:本文不仅提供了理论知识,还结合了大量代码案例,帮助读者更好地理解和实践Kotlin的函数式编程特性和跨平台开发能力。建议读者在学习过程中动手实践代码案例,以加深理解和掌握。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值