zoukankan      html  css  js  c++  java
  • mysql之sql查询结果集小数保留

     引用:https://www.cnblogs.com/QscTiger/p/5440294.html

     客户要求,跟金额相关的数据,打印出来要保留两位小数,比如:13.2/13.200要显示为13.20;

    分析:

    首先查看数据库中的数据定义,均为decimal(12,2) ,直接通过数据库查询的结果也会保留两位小数,但是代码处理后,却会忽略掉最后一个“零”位。

    此处有两个解决方案:

      一、 代码中处理,检测到为金额字段,做特殊处理;二、修改查询SQL语句去规避此问题; 第一种方法,无论通过数据类型还是字段名称,都不好判断是否为金额,故选用第二种方法。

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

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

    复制代码
    SELECT ROUND(123.9994, 3)   --123.9990
    SELECT 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 DECIMAL(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

     注:必须保证显示的位数,大于保留的小数位数,不然会出错。

            数据最好采用varchar类型存储。

    不建议使用convert.

    根据需求这里采用第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 ')+'%'      --hello world%
    SELECT RTRIM('hello' + ' ' + 'world ')+'%'      --hello world%
  • 相关阅读:
    Java笔记(一)Eclipse 操作MySQL数据库的效率问题
    C# 笔记(六)关于switch 语句
    C# 笔记(五)关于static
    arcgis server 9.3初步
    C# 笔记(三)关于结构体变量
    OpenBSD随笔(一)
    Windows 脚本WSH
    Java笔记(二)Eclipse 连接SQlServer
    ArcGIS Server 9.3 JavaScript API实战(二)一个具体的小系统示例介绍
    C#笔记(二)类型转换
  • 原文地址:https://www.cnblogs.com/mlf19920916/p/12216910.html
Copyright © 2011-2022 走看看