http://www.cnblogs.com/ision/archive/2009/02/13/1390235.HTML
经常要保留小数,在程序中计算太麻烦了,还要转换 *** 作。直接在数据库中 *** 作来得方便。
把数据类型定义成decimal/numeric类型,小数位看需要随意设,除数与被除数必须要有一个为decimal/numeric中的类型,如下例:
SELECT 24.0000/38.0000 --0
SELECT CAST(24/38 AS NUMERIC(18,4)) --0
SELECT CAST(24/38.0000 AS NUMERIC(18,4)) --0.6316 此结果已经四舍五入
SELECT 24.0000/38.0000 --0.6316
decimal/numeric与int类型运算时会得出decimal/numeric类型的结果,因为decimal/numeric的优先级比int高。
参照MSDN上的类型优先级表:
sql Server 2005 对数据类型使用以下优先级顺序:
用户定义数据类型(最高)sql_variant
xml
datetime
smalldatetime
float
real
decimal
money
smallmoney
bigint
int
smallint
tinyint
bit
ntext
text
image
timestamp
uniqueIDentifIEr
nvarchar(包括 nvarchar(max))
nchar
varchar (包括 varchar(max))
char
varbinary(包括 varbinary(max))
binary(最低) 总结
以上是内存溢出为你收集整理的sqlserver中计算结果保留小数全部内容,希望文章能够帮你解决sqlserver中计算结果保留小数所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)