本文摘自PHP中文网,作者jacklove,侵删。
通过如下测试验证,首先建立数据分布不平均的测试表。1 2 3 4 5 6 |
|
然后通过 varhcar和nvarchar值分别测试满足条件1条和满足条件8900条的执行计划预估行数。
1 |
|
得到的查询计划预估行数如下图所示
从图中显示的预估数据行数可以看到,对于varchar值(不需要隐匿的数据类型转换),其预估的结果是准确的。但对于nvarchar值,不管指定的值是只有一条数据,还是有8900条数据匹配,其预估的结果都是99.0099,这说明预估并没有考虑我们指定的值。
进一步用变量测试
1 |
|
结果如下图所示:
不管是varchar,还是nvarchar的变量,预估的行数都是99.0099,这个值与使用nvarchar常量值的结果一样,看来SQL Server查询优化器应该确实把 GetRangeThroughConvert 的结果看成变量了,这个应该是设计上考虑不太周全的地方了,毕竟指定固定常量值的时候,GetRangeThroughConvert的结果应该也是确定值才对。
本文讲解了SQL Server的相关内容,更多相关内容请关注php中文网。
相关推荐:
如何让MySQL中单句实现无限层次父子关系查询
带进度的SQL Server FileStream如何存取
当忘记 SQL Server 管理员密码该如何处理
以上就是SQL Server 2008 处理隐式数据类型转换在执行计划中的增强的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
sql server:alter database name的问题
更多相关阅读请进入《sql》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。