一、问题描述

数据库里的 float momey 类型,都会精确到多位小数。但有时候 我们不需要那么精确,例如,只精确到两位有效数字。

二、sqlserver解决方案:

1. 使用 Round() 函数,如 Round(@num,2) ,其中参数 2 表示 保留两位有效数字。

缺点:Round() 只是负责四舍五入到两位小数,但是不负责去掉后面的0。

print ROUND(13.145, 2);

或者select ROUND(13.145, 2);

结果为:13.150。

2. 使用 Convert(decimal(18,2),@num) 实现转换,其中参数 2 表示 保留两位有效数字。

print Convert(decimal(18,2),13.145)

结果为:13.15。

3.使用 cast(@num as decimal(18,2)) 实现转换,其中参数 2 表示 保留两位有效数字。

print cast(13.145  as  decimal(18,2))

结果为:13.15。

三、CAST与CONVERT比较

1、CAST与CONVERT相同点:

在大部分情况下,两者执行同样的功能,都可以执行数据类型转换,且都默认实现了四舍五入,

相当于 print cast(round(13.145)   as   numeric(18,2))  。

2、CAST与CONVERT不同点:

  CONVERT还提供一些特别的日期格式转换,而CAST没有这个功能。

  既然CONVERT包括了CAST的所有功能,而且CONVERT还能进行日期转换,那么为什么需要使用CAST呢?实际上,这是为了ANSI/ISO兼容。CAST是ANSI兼容的,而CONVERT则不是。

  语法:

  1.   CAST (expression AS data_type [ (length ) ])
  2.  
  3.   CONVERT (data_type [ ( length ) ] , expression [ , style ])

  示例:

  1.   SELECT 'AB' + 1 --此语句报错,在将 varchar 'AB' 转换成数据类型 int 时失败。
  2.  
  3.   SELECT 'AB' + CAST(1 AS varchar) --输出 AB1
  4.  
  5.   SELECT 'AB' + CONVERT(varchar,1) --输出 AB1

  CAST和CONVERT都能转换时间:

  1.   SELECT CONVERT(DateTime,'2011-07-11') --输出 2011-07-11 00:00:00.000
  2.  
  3.   SELECT CAST('2011-07-11' AS DateTime) --输出 2011-07-11 00:00:00.000

  但是时间转字符串,CAST没有CONVERT这么多花样:

  1.   SELECT CONVERT(varchar,GETDATE(),5) --输出 01-07-13
  2.   SELECT CONVERT(varchar,GETDATE(),111) --输出 2013/07/01
  3.   SELECT CONVERT(varchar,GETDATE(),1) --输出 07/01/13
  4.  
  5.   SELECT CAST(GETDATE() AS varchar) --输出 07 1 2013 9:56PM

四、ROUND简单用法

ROUND格式:ROUND(p1,p2,p3)
P1:要被四舍五入的值;
P2:保留的小数位数;
P3:如果为0或不输入,则表示进P1进入四舍五入,如SELECT ROUND(123.86,1) 结果:123.90
如果P3是不为0的数,则对P1进行截断,可以理解为不四舍五入只截断 SELECT ROUND(123.86,1,1) 结果:123.80

注意:当p2为负数时,p1在小数点的左侧舍入。ROUND(748.58,-2) 结果:700.00

SELECT ROUND始终返回一个值。如果p2为负且大于小数点前的位数,则ROUND返回0。ROUND(748.58,-4)结果: 0

SELECT ROUND(748.58,-3)报错:将 expression 转换为数据类型 numeric 时出现算术溢出错误。因为748.58默认为十进制(5,2),不能返回1000.00。

SELECT ROUND(CAST (748.58 AS decimal (6,2)),-3); 结果:1000.00

参考资料:

http://blog.csdn.net/zengcong2013/article/details/46607415

https://www.cnblogs.com/kissdodog/p/3165944.html

https://zhidao.baidu.com/question/1638055421410949060.html

convert()函数

http://www.runoob.com/sql/func-convert.html

Round()函数(重要)

https://docs.microsoft.com/en-us/sql/t-sql/functions/round-transact-sql?view=sql-server-2017

汇总整理:

一、 数据库解决方案:

Round()、Convert()、Cast() 方法

https://www.cnblogs.com/hao-1234-1234/p/8574188.html

三、 前端解决方案:

js中 Math.round()方法

https://www.cnblogs.com/hao-1234-1234/p/11150134.html

四、服务器端解决方案(C#)

Math.Round方法

https://www.cnblogs.com/hao-1234-1234/p/8668258.html

sql 四舍五入 保留两位小数的更多相关文章

  1. sql 四舍五入保留两位小数

    select convert(decimal(18, 2), 362315 * 1.0 / 10000) 1. ROUND(该函数,只是负责四舍五入到两位小数,但是不负责截断 只留两位小数,例如下例: ...

  2. Oracle中,利用sql语句中的函数实现保留两位小数和四舍五入保留两位小数

    Oracle中,利用sql语句中的函数实现保留两位小数和四舍五入保留两位小数: select trunc(1.23856789,2) from dual round(m,n) 可以四舍五入 trunc ...

  3. 装饰者模式的学习(c#) EF SaveChanges() 报错(转载) C# 四舍五入 保留两位小数(转载) DataGridView样式生成器使用说明 MSSQL如何将查询结果拼接成字符串 快递查询 C# 通过smtp直接发送邮件 C# 带参访问接口,WebClient方式 C# 发送手机短信 文件 日志 写入 与读取

    装饰者模式的学习(c#) 案例转自https://www.cnblogs.com/stonefeng/p/5679638.html //主体基类 using System;using System.C ...

  4. JS四舍五入保留两位小数

    //四舍五入保留2位小数(若第二位小数为0,则保留一位小数) function keepTwoDecimal(num) { var result = parseFloat(num); if (isNa ...

  5. 【0624课外作业】将一个double类型的小数,四舍五入保留两位小数

    package com.work0624; /** * 课外作业 *将一个double类型的小数,四舍五入保留两位小数 * @author L * */ import java.util.Scanne ...

  6. 19-6/24作业: 将一个double类型的小数,按照四舍五入保留两位小数

    ☞要求 将一个double类型的小数,按照四舍五入保留两位小数 ☞实现方式 1.获得一个double类型的小数 2.使用BigDecimal包的setScale进行操作 3.输出结果 ☞代码内容 pa ...

  7. Java中四舍五入保留两位小数

    Java中四舍五入保留两位小数 方法一 四舍五入 double f = 3.15; long res = Math.round(f); #结果 res = 3 保留两位小数 double f = 3. ...

  8. js 让小数四舍五入保留两位小数的函数是?

    js 让小数四舍五入保留两位小数的函数是? 例子:data.relations[i].data[j].toFixed(2) toFixed(2)这个函数就是保留两位小数的作用

  9. C# 传统四舍五入保留两位小数(网上流传好多错误的版本)

    关于C#里面的Math.Round,很多人都会用到,而且以为是四舍五入,其实不是这样的: C#里面的Math.Round是符合IEEE标准的“四舍五入”,其实是五舍六入. 网上好多流传的下面这种方式实 ...

随机推荐

  1. RabbitMQ 入门教程(PHP版) 第三部分:发布/订阅(Publish/Subscribe)

    发布/订阅 在上篇第二部分教程中,我们搭建了一个工作队列.每个任务之分发给一个工作者(worker).在本篇教程中,我们要做的之前完全不一样——分发一个消息给多个消费者(consumers).这种模式 ...

  2. Oracle中Sequence使用

    Oracle提供了sequence对象,由系统提供自增长的序列号,通常用于生成数据库数据记录的自增长主键或序号的地方. 下面介绍一下关于sequence 的生成,修改,删除等常用的操作: 1. 创建 ...

  3. ABAP函数篇2 测试DATE_CONVERT_TO_FACTORYDATE

    DATE_CONVERT_TO_FACTORYDATE   根据日期返回工厂日历日期 函数功能说明: 标出工作日的计算方法 输入传输 CORRECT_OPTION = '+'如果指定的日期不是工作日, ...

  4. [ kvm ] 学习笔记 3:KVM 基础功能详解

    1. 构建 KVM 环境 KVM 从诞生开始就需要硬件虚拟化的支持,KVM 必需的硬件虚拟化扩展分别是:Intel 的虚拟化技术(Intel VT)和 AMD 的 AMD-V 技术.首先处理器(CPU ...

  5. python 求交集、并集、差集

    需要用到set类型 交集,两种方法 retA = [i for i in listA if i in listB] retB = setA.intersection(setB) 并集 retC = s ...

  6. web端自动化——Selenium Grid原理

     利用Selenium Grid可以在不同的主机上建立主节点(hub)和分支节点(node),可以使主节点上的测试用例在不同的分支节点上运行.  对不同的节点来说,可以搭建不同的测试环境(操作系统.浏 ...

  7. web端自动化——selenium测试报告生成、找到测试报告路径、实现发邮件(整合)

    有这样的一个场景: 假设生成的测试报告与多人相关,每个人都去测试服务器査看就会比较麻烦,如果把这种主动的且不及时的査看变成被动且及时的査收,就方便多了. 整个程序的执行过程可以分为三个步骤: ①    ...

  8. 什么时候该用readfile() , fread(), file_get_contents(), fgets()?

    fread() 和 readfile() fread() 最大一次性能读取 8k长度的字节数,所以不能一次性读取大文件去作下载. 优势在于,操作更加灵活,每次读取指定字节的内容,用于下载时方便控制服务 ...

  9. gluster设置日志级别

    glusterd --log-level WARNING #将日志级别设定为warning gluster --log-level=ERROR volume status #查看日志级别的状态 glu ...

  10. python 线程队列LifoQueue-LIFO(36)

    在 python线程队列Queue-FIFO  文章中已经介绍了 先进先出队列Queue,而今天给大家介绍的是第二种:线程队列LifoQueue-LIFO,数据先进后出类型,两者有什么区别呢? 一.队 ...