SQL 中数值型数据截取及四舍五入

例一:

-- 将两个数值分别截取只保留两位小数 ( 注意此时字段默认为 decimal )

select CAST ( 10.097 as decimal ( 10, 2))   as [10.097 截取前 ]

,    CAST ( 10.094 as decimal ( 10, 2))   as [10.094 截取前 ]

,    CAST ( 10.145 as decimal ( 10, 2))   as [10.145 截取前 ]

例二:

-- 再次将两个数值分别截取只保留两位小数 ( 注意此时字段类型为 float )

declare @a float , @b float , @c float

set @a = 10.097

set @b = 10.094

set @c = 10.145

select CAST ( @a as decimal ( 10, 2))   as [10.097 截取前 ]

,    CAST ( @b as decimal ( 10, 2))   as [10.094 截取前 ]

,    CAST ( @c as decimal ( 10, 2))   as [10.145 截取前 ]

在做精度和小数位数的转换时 ,也要考虑 decimal 和 float 的不同类型字段的区别 。

否则用 Round 函数也是一样的效果 。

比如 :

declare @a float , @b float , @c float

set @a = 10.097

set @b = 10.094

set @c = 10.145

select ROUND ( @a   , 2)   as [10.097 进位前 ]

,    ROUND ( @b   , 2)   as [10.094 进位前 ]

,    ROUND ( @c , 2)   as [10.145 进位前 ]

--result:

10.097 进位前              10.094 进位前              10.145 进位前

---------------------- ---------------------- ----------------------

10.1                   10.09                  10.14

( 1 行受影响 )

总结 :当字段类型为 float 时 ,进行四舍五入有时会有奇怪的结果产生 ,比如

declare @a float , @b float , @c float

set @a = 0.134

set @b = 0.145

set @c = 0.146

select ROUND ( @a   , 2)   as [0.134 进位前 ]

,    ROUND ( @b   , 2)   as [0.145 进位前 ]

,    ROUND ( @c , 2)   as [0.146 进位前 ]

--result:

0.134 进位前               0.145 进位前               0.146 进位前

---------------------- ---------------------- ----------------------

0.13                   0.14                     0.15

( 1 行受影响 )

当字段类型为 decimal 时 ,对于高精度的小数位四舍五入时 ,并没有产生那样奇怪的结果 。比如 :

declare @a decimal ( 5, 3) , @b decimal ( 5, 3) , @c decimal ( 5, 3)

set @a = 0.134

set @b = 0.145

set @c = 0.146

select ROUND ( @a   , 2)   as [0.134 进位前 ]

,    ROUND ( @b   , 2)   as [0.145 进位前 ]

,    ROUND ( @c , 2)   as [0.146 进位前 ]

--result:

0.134 进位前               0.145 进位前               0.146 进位前

---------------------- ---------------------- ----------------------

0.130                    0.150                     0.150

( 1 行受影响 )

所以我们在进行小数位的计算或转换时 ,我会优先考虑 decimal 类型的数值 。比如 在例一中默认的字段类型即是 decimal ,下面我们来看一下:

--1 、将 0.145 导入临时表

select 0.145 a

into #a

( 1 行受影响 )

-- 查看临时表中 a 字段类型

select

[ 表名 ] = c . Name ,

[ 列名 ] = a . Name ,

[ 标识 ] = case when is_identity = 1 then '√' else '' end ,

[ 类型 ] = b . Name

from

sys . columns a

left join

sys . types b on a . user_type_id = b . user_type_id

inner join

sys . objects c on a . object_id = c . object_id

where left( c . Name , 2)= '#a' and a . name = 'a'

-- 结果如下图示:

所以回看例一 ,在进行数据转换时 ,默认的字段类型仍是 decimal 。

附图 数据类型转换时的行为规范

SQL 中数值型数据截取以及四舍五入的更多相关文章

  1. SQL 中的LastIndexOf,截取最后一次出现字符后面的字符(转)

    SQL如何取出一个字符串中最后一个特殊字符右边的字符,例如:10*20*300,怎样得到300? 使用reverse配合charindex来实现. reverse是把字符串倒置,然后通过charind ...

  2. sql中从指定位置截取指定长度字符串

    1. 字符串函数应用 --从指定索引截取指定长度的字符串 ,) --获取字符串中指定字符的索引(从1开始) select charindex(',','ab,cdefg') --实际应用中的语句 , ...

  3. sql server 数值的四舍五入

    sql中的四舍五入通常会有round  和cast( …… as decimal())两种方式: 个人建议使用cast  方式: 方式1: 经过试验,同样都可以做到四舍五入,但round如下实例1会报 ...

  4. SQL零星技术点:SQL中转换money类型数值转换为字符串问题

    --SQL中转换money类型数值转换为字符串问题,直接转换就转为两位了,所以需要做一下处理.具体请看下述sql实例. 1 create table #test(price money) insert ...

  5. 获取数值型数组中大于60的元素个数,给数值型数组中不足60分的加20分。(数组,for循环,if条件判断语句)

    package com.Summer_0420.cn; /** * @author Summer * 获取数值型数组中大于60的元素个数 * 给数值型数组中不足60分的加20分 */ public c ...

  6. SQL中字符串截取、连接、替换等函数的用法

    一.SQL中SUBSTRING函数的用法1.功能:返回字符.二进制.文本或图像表达式的一部分2.语法:SUBSTRING ( expression, start, length )3.QL 中的 su ...

  7. sql中的字符串匹配、函数大全

    假设你想建立一个与Yahoo功能相似的Internet目录.你可以建立一个表用来保存一系列的站点名称,统一资源定位器(URL),描述,和类别,并答应访问者通过在HTML form中输入要害字来检索这些 ...

  8. sql中的函数

    函数类别 作用 聚合函数 执行的操作是将多个值合并为一个值.例如 COUNT.SUM.MIN 和 MAX. 配置函数 是一种标量函数,可返回有关配置设置的信息. 转换函数 将值从一种数据类型转换为另一 ...

  9. SQL中Round(),Floor(),Ceiling()函数的浅析

    项目中的一个功能模块上用到了标量值函数,函数中又有ceiling()函数的用法,自己找了一些资料,对SQL中这几个函数做一个简单的记录,方便自己学习.有不足之处欢迎拍砖补充 1.round()函数遵循 ...

随机推荐

  1. 简单聊下IO复用

    没图,不分析API Java中IO API的发展:Socket -> SocketChannel -> AsynchronousSocketChannelServerSocket -> ...

  2. __set(),__get() 魔术方法示例

    <?php class Ren{private $name;private $age;private $sex;function __set($name,$value){ if($name == ...

  3. vsPhere安装虚拟sm

    1.在机器上单击右键 2.选择“编辑设置” 设备状态,选择打开电源时链接,数据存储ISO文件,选择镜象. 3.重启,进入安装界面. 4.

  4. 2015安徽省赛 D.锐雯上单不给就送

    题目描述 <英雄联盟>(简称LOL)是由美国Riot Games开发,腾讯游戏运营的英雄对战网游.<英雄联盟>除了即时战略.团队作战外,还拥有特色的英雄.自动匹配的战网平台,包 ...

  5. C++中new的解说

    new int;//开辟一个存放整数的存储空间,返回一个指向该存储空间的地址(即指针) new int(100);//开辟一个存放整数的空间,并指定该整数的初值为100,返回一个指向该存储空间的地址 ...

  6. PHP 遍历数组的方法汇总

    1. foreach() foreach()是一个用来遍历数组中数据的最简单有效的方法. #example1: <?php $colors= array('red','blue','green' ...

  7. shell中常用的命令方法

    <1>Linux Shell 脚本中字符串的连接方法 [root@localhost company]# var1=/etc/[root@localhost company]# var3= ...

  8. 1-2+3-4+5-6+7......+n的几种实现

    本文的内容本身来自一个名校计算机生的一次面试经历,呵呵,没错,你猜对了,肯定 不是我 个人很喜欢这两道题,可能题目原本不止两道,当然,我这里这分析我很喜欢的两道. 1.写一个函数计算当参数为n(n很大 ...

  9. 《ASP.NET MVC4 WEB编程》学习笔记------HtmlHelper

    本文转载自powerzhang,如果给您带来不便请联系博主. 在实际的程序中,除了在View中展示数据外,还需要在View与后台的数据进行交互,在View中我就需要用的表单相关的元素: 在MVC3框架 ...

  10. Windows下使用命令行设置ip地址的DNS服务器

    使用命令行或者编写bat批处理设置网络连接的IP地址以及DNS服务器地址有时候会比手动更加方便,IP地址和DNS的设置一般是配合的,常用到的几个状态是: 1.IP地址动态获取,DNS也动态 2.IP地 ...