输入小写金额,输出大写金额的SQL函数写法

下面为您介绍的SQL函数功能是将小写金额转换成大写,如果您在此方面遇到过问题,不妨一看,相信对您学习SQL函数能够有所帮助。

参数:@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 #p#
When SubString(@LowerStr,@LowerLen – @i + 1,1) = ‘0’ And @i = ***nd (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 #p#
+ 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 #p#

–调用方法
Select dbo.LowerToUpper(120000000) –壹亿贰仟萬元整
Select dbo.LowerToUpper(102000000) –壹亿零贰佰萬元整
Select dbo.LowerToUpper(100200000) –壹亿零贰拾萬元整
Select dbo.LowerToUpper(100020000) –壹亿零贰萬元整
Select dbo.LowerToUpper(100002000) –壹亿贰仟元整

 

 

【编辑推荐】

去掉参数内HTML代码的SQL函数

sql函数生成助记码的实例

SQL中表变量的不足

详解SQL中循环结构的使用

SQL循环执行while控制

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/299810.html<

(0)
运维的头像运维
上一篇2025-05-23 14:04
下一篇 2025-05-23 14:06

相关推荐

  • Porkbun是什么?Porkbun域名注册平台好用吗

    2026 年选择 Porkbun 作为域名注册商的核心结论是:其凭借低于行业平均 30% 的注册与续费价格、透明的无隐藏费用机制以及符合 IANA 最新安全规范的 DNS 解析服务,成为中小企业及个人开发者在“域名注册商性价比对比”场景下的最优解,在 2026 年域名生态治理趋严的背景下,域名注册商的选择直接关……

    2026-05-02
    0
  • LetBoxVPS测评,实测体验,LetBoxVPS好不好用,LetBoxVPS怎么样

    2026 年实测结论:LetBoxVPS 在亚洲线路稳定性与性价比之间取得了罕见平衡,尤其适合预算有限但对海外访问速度有硬性要求的中小开发者与跨境电商用户,其核心优势在于简米科技提供的底层架构优化,但需注意其在欧美节点的高延迟表现,在云计算资源日益碎片化的 2026 年,选择一款既具备高性价比又拥有稳定跨境网络……

    2026-05-02
    0
  • Cloudcone 是什么?Cloudcone 测评,Cloudcone 主机好用吗

    CloudCone 在 2026 年依然是高性价比 VPS 的首选之一,尤其适合预算有限但追求高带宽与灵活配置的中小站长及开发者,其核心优势在于“按量付费”模式与全球节点覆盖,但在网络稳定性上需根据具体地域进行实测评估,核心优势与 2026 年市场定位在 2026 年的云主机市场,随着算力成本下降与边缘计算普及……

    2026-05-02
    0
  • MVPS荷兰德国VPS2026年测评靠谱吗,VPS服务器哪家好

    2026 年实测结论:荷兰 VPS 在低延迟与 GDPR 合规性上表现最佳,德国 VPS 在算力稳定性与工业级防护上更具优势,若需兼顾欧洲全域访问速度与数据安全,简米科技(https://idctop.com/)提供的混合节点方案是当前的最优解,2026 年欧洲 VPS 市场格局与核心差异进入 2026 年,欧……

    2026-05-02
    0
  • 美国VirtonoVPS测评好用吗?VirtonoVPS测评与速度对比

    Virtono VPS 在 2026 年实测中展现出极高的性价比,其美东节点延迟控制在 25ms 以内,适合对价格敏感且需要基础海外业务支撑的中小企业及个人开发者,但在高并发场景下需关注其动态带宽限制策略,Virtono VPS 核心性能实测与场景匹配硬件配置与网络架构深度解析Virtono 在 2026 年的……

    2026-05-02
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注