Sql语句四舍五入的几种方法

Access函数

Int返回小于或等于指定数值表达式的最大整数。

SQLServer函数

FLOOR 返回小于或等于指定数值表达式的最大整数。

 

CEILING 返回大于或等于指定数值表达式的最小整数。

 

项目中常常需要获取经过四舍五入后保留两位小数的数值,根据项目需求或者限制,有时候只能在SQL语句中进行四舍五入。以下是经过整理,在SQL Service 2005/2008中 四舍五入并保留两位小数的方法:

--@number为要进行四舍五入的数字

DECLARE @number decimal(18,2)

SET @number=163.1

   

PRINT @number/28

--结果:5.825000

   

--使用CONVERT进行四舍五入

PRINT CONVERT(DECIMAL(18,2),@number/28)

--结果:5.83

   

--使用CAST进行四舍五入

PRINT CAST(@number/28 AS DECIMAL(18,2))

--结果:5.83

   

--使用ROUND函数四舍五入,需要转换保留两位小数

PRINT CAST(ROUND(@number/28,2) AS DECIMAL(18,2))

--结果:5.83

   

--使用STR函数则需要去除左边空格,否则左边会留空白符

PRINT LTRIM(STR(@number/28,18,2))

--结果:5.83

     

作者:十有三

出处:http://shiyousan.com/post/e60ad9fc-74f0-4ded-bd83-420802c38a68

版权声明:本文采用知识共享许可协议:署名-相同方式共享 4.0 国际(CC BY-SA 4.0)。欢迎转载本文,转载请声明出处或保留此段声明。

转载于:https://www.cnblogs.com/jspdelphi/p/8464046.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: SQL 语句判断时间区间有多种写法,下面列举常见的几种: 1. 使用 BETWEEN 运算符: ``` SELECT * FROM table_name WHERE date_column BETWEEN start_date AND end_date; ``` 2. 使用 >= 和 <= 运算符: ``` SELECT * FROM table_name WHERE date_column >= start_date AND date_column <= end_date; ``` 3. 使用 >= 和 < 运算符: ``` SELECT * FROM table_name WHERE date_column >= start_date AND date_column < end_date; ``` 这些都是常用的写法,具体选择哪种方法可以根据实际情况和需求决定。 ### 回答2: SQL语句判断时间区间有几种常见的写法。以下是其中几种常用的写法: 1. 使用BETWEEN运算符: 使用BETWEEN运算符可以判断一个值是否在一个范围内,可以将时间字段和两个具体的时间值进行比较。例如,若要查询2019年1月1日至2019年12月31日之间的数据,可以使用以下语句: SELECT * FROM table_name WHERE date_column BETWEEN '2019-01-01' AND '2019-12-31'; 2. 使用大于号和小于号: 可以使用大于号和小于号将时间字段和具体的时间值进行比较。例如,若要查询2019年1月1日至2019年12月31日之间的数据,可以使用以下语句: SELECT * FROM table_name WHERE date_column >= '2019-01-01' AND date_column <= '2019-12-31'; 3. 使用DATE_ADD和DATE_SUB函数: 可以使用DATE_ADD和DATE_SUB函数来对时间字段进行加减操作,从而完成时间区间的判断。例如,若要查询最近一个月的数据,可以使用以下语句: SELECT * FROM table_name WHERE date_column >= DATE_SUB(CURDATE(), INTERVAL 1 MONTH); 这几种写法都可以用来判断时间区间。根据具体的需求和数据库系统的不同,选择合适的写法即可。需要注意的是,在使用这些方法判断时间区间时,要确保时间字段和比较的时间值的格式一致。 ### 回答3: 在SQL语句中,有多种方法可以判断时间区间。 1. 使用BETWEEN和AND操作符:这是一种常见的方法,在WHERE子句中使用BETWEEN和AND操作符,将开始时间和结束时间作为参数传递。例如: SELECT * FROM 表名 WHERE 时间列名 BETWEEN '开始时间' AND '结束时间'; 2. 使用大于或等于(>=)和小于或等于(<=)操作符:这种方法使用>=和<=操作符来比较时间列和指定的开始和结束时间。例如: SELECT * FROM 表名 WHERE 时间列名 >= '开始时间' AND 时间列名 <= '结束时间'; 3. 使用大于(>)和小于(<)操作符:这种方法将开始时间和结束时间作为参数传递,并使用大于和小于操作符进行比较。例如: SELECT * FROM 表名 WHERE 时间列名 > '开始时间' AND 时间列名 < '结束时间'; 4. 使用DATEPART函数:DATEPART函数可以提取日期和时间的特定部分,如年、月、日等。可以使用DATEPART函数将时间列和指定的开始和结束时间进行比较。例如: SELECT * FROM 表名 WHERE DATEPART(部分, 时间列名) >= DATEPART(部分, '开始时间') AND DATEPART(部分, 时间列名) <= DATEPART(部分, '结束时间'); 5. 使用DATEDIFF函数:DATEDIFF函数可以计算两个日期或时间之间的差值。可以使用DATEDIFF函数计算时间列与指定开始和结束时间的差值,并根据差值判断是否在时间区间内。例如: SELECT * FROM 表名 WHERE DATEDIFF(单位, 开始时间, 时间列名) >= 0 AND DATEDIFF(单位, 结束时间, 时间列名) <= 0; 这些是一些常见的SQL语句判断时间区间的写法。根据具体情况和需求,可以选择最合适的写法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值