码迷,mamicode.com
首页 > 数据库 > 详细

在MSSQL中将数字转换成中文

时间:2015-06-09 23:18:44      阅读:175      评论:0      收藏:0      [点我收藏+]

标签:

具体代码如下:

CREATE FUNCTION [dbo].[fn_NumberToChinese] (@number INT)
RETURNS VARCHAR(20)
AS
    BEGIN
        DECLARE @res VARCHAR(20);
        DECLARE @str VARCHAR(10);
        DECLARE @char CHAR(1);
        SET @res = ‘‘;
        SET @str = CAST(@number AS VARCHAR);
        SET @char = SUBSTRING(@str, 1, 1);
        SELECT  @res = ( CASE ( CAST(@char AS INT) )
                           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 
                           ELSE 
                         END );
        IF ( LEN(@str) > 1 )
            BEGIN
                SELECT  @res = @res + ( CASE LEN(@str)
                                          WHEN 2 THEN 
                                          WHEN 3 THEN 
                                          WHEN 4 THEN 
                                          WHEN 5 THEN 
                                          WHEN 6 THEN 
                                          WHEN 7 THEN 
                                          ELSE ‘‘
                                        END );
                SET @res = @res
                    + dbo.fn_NumberToChinese(CAST(SUBSTRING(@str, 2,
                                                              LEN(@str) - 1) AS INT));
            END;
        RETURN @res; 
END;

使用:

SELECT dbo.fn_NumberToChinese(21)

结果:

  二十一

在MSSQL中将数字转换成中文

标签:

原文地址:http://www.cnblogs.com/zuqing/p/4564619.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!