我也来一道题,先不要运行,猜猜结果

CN_SQL 2008-09-20 04:20:03

declare @d1 decimal(38,20)
declare @d2 decimal(38,20)

declare @d3 decimal
declare @d4 decimal


set @d1 = '1.0000'
set @d2 = '3.0000'
set @d3 = '1.0000'
set @d4 = '3.0000'


select @d1 / @d2
select @d3 / @d4

谁答对,100分给他
...全文
179 34 打赏 收藏 转发到动态 举报
写回复
用AI写文章
34 条回复
切换为时间正序
请发表友善的回复…
发表回复
113244 2008-09-22
  • 打赏
  • 举报
回复
.333333
.3333333333333333333
青锋-SS 2008-09-22
  • 打赏
  • 举报
回复
飞过
flairsky 2008-09-22
  • 打赏
  • 举报
回复
恩,又学到一点知识
CN_SQL 2008-09-22
  • 打赏
  • 举报
回复
[Quote=引用 32 楼 liangCK 的回复:]
http://topic.csdn.net/u/20070926/11/6197d973-0842-402a-bf57-66eaf6e95f42.html
看看这帖..看看老大是怎么说的..
[/Quote]
OK,小梁给出了我想给出的,结帖了。
rockyvan 2008-09-22
  • 打赏
  • 举报
回复
[Quote=引用 32 楼 liangCK 的回复:]
http://topic.csdn.net/u/20070926/11/6197d973-0842-402a-bf57-66eaf6e95f42.html
看看这帖..看看老大是怎么说的..
[/Quote]
不錯!
liangCK 2008-09-22
  • 打赏
  • 举报
回复
http://topic.csdn.net/u/20070926/11/6197d973-0842-402a-bf57-66eaf6e95f42.html
看看这帖..看看老大是怎么说的..
CN_SQL 2008-09-21
  • 打赏
  • 举报
回复
恩,是有帮助说明,是那样
但如果根本就没有这篇说明文档,你可以用T-SQL去求证么?
这个才是我想分享给大家的。
richnaly 2008-09-21
  • 打赏
  • 举报
回复
支持,关注啊~~~~~~~~~~
水族杰纶 2008-09-21
  • 打赏
  • 举报
回复
...学习了~~~~~~~~~
czx33859066 2008-09-21
  • 打赏
  • 举报
回复
up
sunshine_anycall 2008-09-21
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 liangCK 的回复:]
关注..
[/Quote]!
昵称被占用了 2008-09-21
  • 打赏
  • 举报
回复
.
prcgolf 2008-09-21
  • 打赏
  • 举报
回复
up
alen88 2008-09-21
  • 打赏
  • 举报
回复
学习了
yangkunjie 2008-09-20
  • 打赏
  • 举报
回复
接分再看
zhihuixiaole 2008-09-20
  • 打赏
  • 举报
回复
有啥意思,jf
tianhuo_soft 2008-09-20
  • 打赏
  • 举报
回复
精度是数字中的数字个数。小数位数是数中小数点右边的数字个数。例如,数 123.45 的精度是 5,小数位数是 2。

在 SQL Server 2005 中,numeric 和 decimal 数据类型的默认最大精度为 38。在 SQL Server 的早期版本中,默认的最大精度为 28。

数字数据类型的长度是存储此数所占用的字节数。字符串或 Unicode 数据类型的长度是字符个数。binary、varbinary 和 image 数据类型的长度是字节数。例如,int 数据类型可以有 10 位数,用 4 个字节存储,不接受小数点。int 数据类型的精度是 10,长度是 4,小数位数是 0。

当两个 char、varchar、binary 或 varbinary 表达式串联时,所生成表达式的长度是两个源表达式长度之和,或是 8,000 字符,以二者中少者计。

当两个 nchar 或 nvarchar 表达式串联时,所生成表达式的长度是两个源表达式长度之和,或是 4,000 字符,以二者中少者计。

使用 UNION、EXCEPT 或 INTERSECT 对数据类型相同但长度不同的两个表达式进行比较时,得到的长度为两个表达式中较大的长度。

除了 decimal 类型之外,数字数据类型的精度和小数位数是固定的。如果算术运算符有两个相同类型的表达式,结果就为该数据类型,并且具有对此类型定义的精度和小数位数。如果运算符有两个不同数字数据类型的表达式,则由数据类型优先级决定结果的数据类型。结果具有为该数据类型定义的精度和小数位数。

下表定义了当运算结果是 decimal 类型时,如何计算结果的精度和小数位数。当下列任一条件成立时,结果为 decimal:

两个表达式都是 decimal 类型。

一个表达式是 decimal 类型,而另一个是比 decimal 优先级低的数据类型。

操作数表达式由表达式 e1(精度为 p1,小数位数为 s1)和表达式 e2(精度为 p2,小数位数为 s2)来表示。非 decimal 类型的任何表达式的精度和小数位数,是对此表达式数据类型定义的精度和小数位数。

运算 结果精度 结果小数位数 *
e1 + e2
max(s1, s2) + max(p1-s1, p2-s2) + 1
max(s1, s2)

e1 - e2
max(s1, s2) + max(p1-s1, p2-s2) + 1
max(s1, s2)

e1 * e2
p1 + p2 + 1
s1 + s2

e1 / e2
p1 - s1 + s2 + max(6, s1 + p2 + 1)
max(6, s1 + p2 + 1)

e1 { UNION | EXCEPT | INTERSECT } e2
max(s1, s2) + max(p1-s1, p2-s2)
max(s1, s2)


* 结果精度和小数位数的绝对最大值为 38。当结果精度大于 38 时,相应的小数位数会减少,以避免结果的整数部分被截断。

想飞的狼 2008-09-20
  • 打赏
  • 举报
回复
接分!
areswang 2008-09-20
  • 打赏
  • 举报
回复
看题,接分!
wzy_love_sly 2008-09-20
  • 打赏
  • 举报
回复
以前研究过一次,msdn就有帮助
http://msdn.microsoft.com/zh-cn/library/ms190476(SQL.90).aspx
加载更多回复(14)

11,849

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 非技术版
社区管理员
  • 非技术版社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧