sql server 2008 整数相除四舍五入

declare@dividendint,@divisorintset@dividend=5set@divisor=3selectcast(round(5/3,3)asin... declare @dividend int,@divisor int
set @dividend=5
set @divisor=3
select cast(round(5/3,3) as int)

这个查询出来的是 1 ,按照常理是5除以3 应该大约等于 1.6,四舍五入应该等于2,我的这个方法不行的,有没有高手知道 2个整数相除怎么四舍五入得到整数啊
展开
 我来答
hy1397471
2015-12-08 · 知道合伙人软件行家
hy1397471
知道合伙人软件行家
采纳数:4714 获赞数:17154
15年数据库维护及数据库应用系统开发经验,从事零售业、服务业及财务管理类系统开发与维护。

向TA提问 私信TA
展开全部

sql server 2008 整数相除需要除数或被除数有一个数据类型为小数,才可以四舍五入。


首先看一个例子,如图:


两条语句唯一区别就是 10 与 10.00

1、select cast(round(10/6,0) as int)       结果:1

2、select cast(round(10.00/6,0) as int)  结果:2

但结果确不一样。


原因是SQLserver有默认的数据类型转换。

10/6 默认转换为整型 即:10/6 = 1。那么 round(1) = 1

10.00/6 默认转换为小数即:10.00/6 = 1.666666 ,那么 round(1.666666,0) = 2

大雅新科技有限公司
2024-11-19 广告
这方面更多更全面的信息其实可以找下大雅新。深圳市大雅新科技有限公司从事KVM延长器,DVI延长器,USB延长器,键盘鼠标延长器,双绞线视频传输器,VGA视频双绞线传输器,VGA延长器,VGA视频延长器,DVI KVM 切换器等,优质供应商,... 点击进入详情页
本回答由大雅新科技有限公司提供
0808xyj
2015-02-07 · TA获得超过1891个赞
知道大有可为答主
回答量:1237
采纳率:100%
帮助的人:1075万
展开全部
declare @dividend int,@divisor numeric(18,2)
set @dividend=5
set @divisor=3.0
select cast(round(@dividend/@divisor,0) as int)
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式