首页 新闻 论坛 群组 Blog 文档 下载 读书 Tag 网摘 搜索 .NET Java 游戏 视频 人才 外包 培训 数据库 书店 程序员
中国软件网
欢迎您:游客 | 登录 注册 帮助
  • 求一sql函数,输入小写金额,输出大写金额! [已结贴,结贴人:photo2008]
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • photo2008
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    • 揭帖率:
    发表于:2008-07-10 23:23:45 楼主
    我要在sql里面处理,用一个sql函数
    输入float型,输出字符串型

    例如 function dbo.mm( @dd float)
    return varchar(200)

    输入1200
    输出壹千贰百元

    输入10399
    输出壹万零三百九十九元
    100  修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • silentwins
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    • 2

      2

    发表于:2008-07-10 23:56:551楼 得分:20
    编写者:(博客天地 www.inbaidu.com )
    创建时间:20071023
    功能:小写金额转换成大写
    参数:@LowerMoney 小写金额 加上小数点最长可以保留38位
    输出:大写金额
    简介:SQL版 小写金额转换成大写金额(最多可以精确到小数点四位)
    注:      Decimal 数据类型最多可存储 38 个数字
    转载:请保留以上信息,谢谢!!!
    ********************************************************/

    SET QUOTED_IDENTIFIER ON
    GO
    SET ANSI_NULLS ON
    GO

    Create Function 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型的值全部赋给字符串变量 注:(赋值过去的话如8 在字符串变量中是显示8.0000 因为小数位精确到四位,没有的话,它会自动补0)
          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 '元'      --注:如果个位为0的话,并且四位小数都是0或者它的长度超过5(也就是超过元),则为元
                                      --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型最大长度是38 后面的就不用再考虑了
                                                  Else
                                                      + Case @i%4
                                                              When 2 Then '拾'      --拾 6 10 14 18 22 26 30 34 38 …………
                                                              When 3 Then '佰'      --佰 7 11 15 19 23 27 31 35 39 …………
                                                              When 0 Then '仟'      --仟 8 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) + '整' --判断小数位数是不是都是0,是0就可以取整
          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) --判断当前否是零元开头,并且后面的四个小数不为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                            --如果只是0的话,就显示零元整
          Return @UpperStr      --返回大写金额
    End 

    GO
    SET QUOTED_IDENTIFIER OFF
    GO
    SET ANSI_NULLS ON
    GO


    --调用方法
    Select dbo.LowerToUpper(120000000) --壹亿贰仟萬元整
    Select dbo.LowerToUpper(102000000) --壹亿零贰佰萬元整
    Select dbo.LowerToUpper(100200000) --壹亿零贰拾萬元整
    Select dbo.LowerToUpper(100020000) --壹亿零贰萬元整
    Select dbo.LowerToUpper(100002000) --壹亿贰仟元整
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • wuyanteng1
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-10 23:57:272楼 得分:0
    select CAST ( 10399 AS VARCHAR(10) ) as 字段名
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • benbenkui
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 06:51:423楼 得分:0
    收藏,顶
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • sheng9hhd
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 07:27:354楼 得分:0
    这个绝对要收藏!!!
    沟穰杼垓京兆亿萬---〉-_-!
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • yyj135
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 08:24:205楼 得分:0
    一楼不是一般的强。
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • tianhuo_soft
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 08:28:266楼 得分:10
    SQL code
    金额有一定的限制,不能是壹仟万亿以上的数字。 --drop proc ConvertToUpperCase /*declare @a varchar(50) --@a为欲转换的大写金额 exec ConvertToUpperCase 1000000,@a output --将123456789.56转换成大写金额 select @a --在QA中查看效果 */ /*declare @a varchar(50) --@a为欲转换的大写金额 exec ConvertToUpperCase 1056031010000,@a output select @a */ if exists (select * from sysobjects where objectproperty(object_id('ConvertToUpperCase'), 'IsProcedure') = 1) drop procedure ConvertToUpperCase GO 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 = '佰拾万仟佰拾亿仟佰拾万仟佰拾元' --加大范围,这里设计len(@sUpperMoney)<=15,再大这种算法就不适合了。 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,'亿零') if substring(@sTemp,1,2)='万零' and @nStep<4--修改 select @sTemp=stuff(@sTemp,1,2,'') select @nIsZeroLast = 2 end else begin select @sTemp = @sth + @sTemp if substring(@sTemp,1,2)='万元' and @nStep>4--修改 select @sTemp=stuff(@sTemp,1,2,'') if substring(@sTemp,1,3)='亿万元' select @sTemp=stuff(@sTemp,1,3,'亿元') select @nIsZeroLast = 2 end end else select @nIsZeroLast = 1 end else --@nIsZeroLast = 2 begin if (@sth = '') select @nIsZeroLast = 0 end end --@nIsZeroLast <> 2 select @nStep = @nStep - 1 end --while @nStep > 0 declare @sTempLittle varchar(10),@sFirst char(1),@sSecond char(1) select @sFirst = '',@sSecond = '' if Len(@sLittle) = 2 begin select @sFirst = substring(@sLittle,1,1),@sSecond = substring(@sLittle,2,1) end if Len(@sLittle) = 1 begin select @sFirst = substring(@sLittle,1,1) end select @sTempLittle = '' if (@sFirst <> '') and (@sFirst <> '0') begin select @sNumber = substring(@sUpperNumbers,10 - convert(int,@sFirst),1) select @sTempLittle = @sTempLittle + @sNumber + '' end if (@sSecond <> '') and (@sSecond <> '0') begin select @sNumber = substring(@sUpperNumbers,10 - convert(int,@sSecond),1) select @sTempLittle = @sTempLittle + @sNumber + '' end select @sRetUpperMoney = @sMoney + @sTemp + @sTempLittle end
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • xocom
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 08:31:187楼 得分:0
    MARK~~
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • clxcxx
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 08:32:418楼 得分:0
    MARK!
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • AlexJinni
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 08:40:429楼 得分:0
    引用 8 楼 clxcxx 的回复:
    MARK!


    同上
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • microsoftzxw
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 08:42:2410楼 得分:0
    该回复于2008-07-11 10:00:53被版主删除
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • SSXYC
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 08:45:5311楼 得分:0
    好,收藏
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • gaoweipeng
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 08:49:5712楼 得分:0
    好难啊!
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • luckyboy101
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 08:51:2913楼 得分:0
    MARK!
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • sxmonsy
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-07-11 08:56:4914楼 得分:0
    路过的,学习下看看
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天<