开发者

使用SQL保留两位小数的实现方式

开发者 https://www.devze.com 2024-11-05 10:29 出处:网络 作者: YD_1989
目录SQL保留两位小数的实现方式1、使用ROzpoOSlxUND()函数2、使用CONVERT()函数3、使用CAST()函数总结SQL保留两位小数的实现方式
目录
  • SQL保留两位小数的实现方式
    • 1、使用ROzpoOSlxUND()函数
    • 2、使用CONVERT()函数
    • 3、使用CAST()函数
  • 总结

    SQL保留两位小数的实现方式

    SQL中保留两位小数的方法有三种,(第2、3种方法类似):

    1、使用ROUND()函数

    ROUND返回一个数值,舍入到指定的长度或精度,使用示例:

    SELECT ROUND(123.9994, 3)   --123.9990
    SELEphpCT ROUND(123.9995, 3)   --124.0000
    SELECT ROUND(748.584, -1)   --750.000
    SELECT ROUND(748.586, -2)   --700.000
    SELECT ROUND(748.586, -3)   --Error 将expression转换为数据类型 numeric 时出现算术溢出错误
    SELECT ROUND(748.586, -4)   --0.000,如果length为负数,并且大于小数点前的数字个数,则ROUND将返回 0
    SELECT ROUND(151.75, 0,0)   --152.00 舍入
    SELECT ROUND(151.75, 0,1)   --151.00 截断

    2、使用CONVERT()函数

    使用示例:

    SELECT CONVERT(DECIMAL(13,2),13.123) --13.12 

    3、使用CAST()函数

    使用示例:

    SELECT CAST(13.123 as DEC编程客栈IMAL(13,2)) --13.12 

    这三种方法(其实是两种),还是有区别的

    区别在于ROUND()只是进行四舍五入,仍然会保留后面的位数为0,但是convert()和cast() 却会截断后面的位数

    示例:

    SELECT CONVERT(DECIMAL(13,2),13.123)    --13.12
    SELECT CAST(13.123 as DECIMAL(13,2))    --13.12
    SELECT ROUND(13.123,2)                  --13.120

    根据需求这里采用第2种方案,但是仅这样处理还是不够的,返回的float型,经过代码处理后,仍然会舍去最后的"0"位。

    最终的解决方案为:

    数据库查询时,编程客栈把float型数据转换为字符型,再交由代码处理返回给客户端。

    具体实现为:

    SELECT RTRIM(CONVERT(DECIMAL(13,2),13.123)) 

    附RTRIM()的用法,返回删除了尾随空格的字符表达式。

    RTRIM(character expression)

    示例:

    SELECT RTRIM('Hello   ')+'%'                    --Hello%
    SELECT RTRIM('Hello')+'%'                       --Hello%
    SELECT RTRIM('hello ' + '' + 'world ')+'%'      --helloworld%
    SELECT RTRIM('hello ' + '' + 'world ')+'%'   www.devze.com   --hello world%
    SELECT RTRIM('hello' + ' ' + 'world ')+'%'      --hello world%

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程客栈(www.devze.com)。

    0

    精彩评论

    暂无评论...
    验证码 换一张
    取 消