--功能:  用于将小写的数值翻译成大写的字符串(支持到分,即小数点后两位)      
--入口参数:@decNum------数字型变量   
--返回:字符串   
--举例:select dbo.fn_ChnMoney(623.88)   
--    结果为“陆佰贰拾叁元捌角捌分”    
--如果小数点毒打两位结果是四舍五入的
--select dbo.[fn_ChnMoney_New](623.88666666)

-- Drop FUNCTION [dbo].[fn_ChnMoney_New]
CREATE  FUNCTION [dbo].[fn_ChnMoney_New](@decNum decimal(18,2)) 
RETURNS varchar(200) 
AS 
BEGIN 
 DECLARE @chvNum varchar(200) 
 DECLARE @chvMoney varchar(200) 
 DECLARE @chvTemp varchar(200) 
 DECLARE @intIntLen int 
 DECLARE @intI int 
 DECLARE @chvTempI varchar(200) 
 DECLARE @chvReturn varchar(200) 
 DECLARE @sFsFlag int 
 
 SET @sFsFlag = 0 
 
 IF @decNum=0  
  SET @chvReturn = '零' 
        Else 
 BEGIN 
  
  IF @decNum<0 
  BEGIN 
   SET @sFsFlag = 1 
   SET @decNum = ABS(@decNum) 
  END 
 
  SET @chvTemp=convert(varchar(200),Round(@decNum*100,0)) 
  IF charindex('.',@chvTemp,1)>0 
   SET @chvNum=left(@chvTemp,charindex('.',@chvTemp,1)-1) 
  ELSE 
   SET @chvNum=@chvTemp 
   
   
  SET @intIntLen=len(@chvNum) 
   
  SET @chvMoney='' 
  Set @chvReturn = '' 
  SET @intI=1 
   
  WHILE @intI <= @intIntLen 
  BEGIN 
   SET @chvTempI = substring(@chvNum,@intIntLen-@intI+1,1) 
   SET @chvMoney = substring('零壹贰叁肆伍陆柒捌玖',convert(int,@chvTempI)+1,1) + substring('分角元拾佰仟万拾佰仟亿拾佰仟兆拾佰仟京拾佰仟',(@intI-1)+1,1) 
   SET @intI = @intI + 1    
    
   SET @chvReturn = @chvMoney + @chvReturn 
  END 
 END 
 
 SET @chvReturn=Replace(@chvReturn,'零仟','零') 
 SET @chvReturn=Replace(@chvReturn,'零佰','零') 
 SET @chvReturn=Replace(@chvReturn,'零拾','零') 
 
 while charindex('零零',@chvReturn,1)>0 
  SET @chvReturn=Replace(@chvReturn,'零零','零') 
 -----增加对京的处理 liuk 
 SET @chvReturn=Replace(@chvReturn,'零京','京') 
  
 SET @chvReturn=Replace(@chvReturn,'零兆','兆') 
 SET @chvReturn=Replace(@chvReturn,'零亿','亿') 
 SET @chvReturn=Replace(@chvReturn,'零万','万') 
 
    -----增加对连体单位的处理 liuk 
    SET @chvReturn=Replace(@chvReturn,'京兆','京') 
 SET @chvReturn=Replace(@chvReturn,'京亿','京') 
 SET @chvReturn=Replace(@chvReturn,'京万','京') 
    SET @chvReturn=Replace(@chvReturn,'兆亿','兆') 
 SET @chvReturn=Replace(@chvReturn,'兆万','兆') 
 SET @chvReturn=Replace(@chvReturn,'亿万','亿') 
 
 
 SET @chvReturn=Replace(@chvReturn,'零元','元') 
 SET @chvReturn=Replace(@chvReturn,'零角零分','整') 
 SET @chvReturn=Replace(@chvReturn,'零角','零') 
 SET @chvReturn=Replace(@chvReturn,'零分','整') 
 SET @chvReturn=LTRIM(RTRIM(@chvReturn)) 
  
 IF @sFsFlag = 1 
  SET @chvReturn = '负' + Ltrim(@chvReturn) 
 
 RETURN @chvReturn 
 
END

SQL函数:用于将小写的数值翻译成大写的字符串的更多相关文章

  1. input输入框输入小写字母自动转换成大写字母

    input输入框输入小写字母自动转换成大写字母有两种方法 1.用js onkeyup事件,即时把字母转换为大写字母: html里input加上 <input type="text&qu ...

  2. C#小写数字金额转换成大写人民币金额的算法

    C#小写数字金额转换成大写人民币金额的算法 第一种方法: using System.Text.RegularExpressions;//首先引入命名空间 private string DaXie(st ...

  3. zip函数用于对列表对应元素打包成元组

    zip() 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表. 如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符,可以 ...

  4. js-input框中写入的小写小写字母全部转换成大写字母的js代码

    <input type="text" id="blinitials" name="blinitials"  onkeyup=" ...

  5. 【东软实训】SQL函数

    SQL函数 SQL是用于访问和处理数据库的标准的计算机语言,我们所使用的的是Oracle SQL 一个数据库通常包含一个或多个表,每个表有一个名字表示,下图即为一个名为“emp”的表,接下来的操作都将 ...

  6. SQL——函数

    演示c_grade表 一.AVG() AVG()函数用于返回数值列的平均值 例: SELECT AVG(score) FROM c_grade; 运行结果: 通过运行结果可以看到,score字段为Nu ...

  7. 把一个string串的所有小写字母转成大写字母的例子来看看看全局函数的使用

    今天写了一个小例子,把字符串里面的所有小写字母全部转换成大写字母http://blog.csdn.net/yasaken/article/details/7303903 1 #include &quo ...

  8. SQL函数:小写金额转换成大写

    /********************************************************作者:版本:1.0创建时间:20020227修改时间:功能:小写金额转换成大写参数:n ...

  9. Oracle数据库常用SQL函数

    1.SQL函数的概念: 函数一般是在数据上执行的,它给数据的转换和处理提供了方便.只是将取出的数据进行处理,不会改变数据库中的值.(类似于java中的方法但函数只是将数据库中的数据取出(复制)到函数中 ...

随机推荐

  1. C语言笔记(枚举)

    关于枚举,在我以前写程序的时候,几乎是没有使用过的,只是偶尔会在一下别人写的驱动库中有看到过.今天看了朱老师的视频,准备将枚举相关的东西总结一下. 一.关于枚举,你需要知道 (1)在C语言中就是一些符 ...

  2. 使用XCode---下载组件

    XCode是一个轻量级的ORM组件(对象与关系数据库映射),提供以面向对象的方式操作数据库的功能,能够解决90%以上的数据库操作场景. 做为X系列组件最重要的一员,XCode秉承了简单实用的特点,力求 ...

  3. 【日语】secret base

    君(きみ)と夏(なつ)の终(お)わり 将来(しょうらい)の梦(ゆめ)Kimi to natsu no owari shourai no yume大(おお)きな希望(きぼう) 忘(わす)れないOoki ...

  4. 如何创建WIN服务

    sc create ServiceName binPath= "XXXX.exe" displayName= "中文xxxx"binpath和displayna ...

  5. [Java I/O] TextFile 工具类

    一种常见的编程任务是,从一个文件读取内容,修改内容,再把内容写到另一个文件里. Java 要实现读取.写入操作,需要创建多个类才能产生一个 Stream 进行操作. 下面是一个简单的工具类,封装对文件 ...

  6. hdu-1242 dfs+各种剪枝

    思路: 可以和1010一个思路.这个抽象的说就是让你求给定图中两点的最短距离,其实dfs的题目能变化的地方就在“终点的回溯处”,在我们到达终点后,再判断一些附加的值(本题里是最短距离是否更新),从而得 ...

  7. Selenium索引

    Common Selenium各种工具比较 Selenium firefox 版本问题 Selenium IDE Selenium IDE整理 WebDriver Java 版本 Selenium开始 ...

  8. UIAlertController 的使用——NS_CLASS_AVAILABLE_IOS(8_0)

    UIAlertView 随着苹果上次iOS 5的发布,对话框视图样式出现在了我们面前,直到现在它都没有发生过很大的变化.下面的代码片段展示了如何初始化和显示一个带有“取消”和“好的”按钮的对话框视图. ...

  9. QE是什么

    量化宽松(Quantitative Easing,简称QE),是一种货币政策,主要指各国央行通过公开市场购买政府债券.银行金融资产等做法.量化宽松直接导致市场的货币供应量增加,可视为变相“印钞”.市场 ...

  10. java笔记8之选择结构IF

    注意1 A比较表达式无论简单还是复杂,结果必须是boolean类型        B:if语句控制的语句体如果是一条语句,大括号可以省略:          如果是多条语句,就不能省略.建议永远不要省 ...