SQL参数化出现执行慢问题

问题: 应用程序通过参数化访问数据库时出现执行效率慢,直接通过语句查时秒出结果,通过参数化查询时用时是前者的几十上百倍。

排查:1.使用了错误的执行计划;

解决:清除缓存的执行计划(未能解决上面问题);

然后百度查了不少资料发现入参的数据类型也会对性能有很大的影响,查代码后发现应用程序调用时对参数类型设置为nvarchar,但是数据库字段类型为varchar,修改代码后性能马上正常了。   

原因:varchar与narchar对应的编码格式(unicode,utf-8,utf-16等等)不同,如果传入参数前后发生了编码格式转化,必定要消耗额外的时间,类型不同会导致索引失效进行全表扫描;

总结:类型转换,索引失效;

PS:如果表数据不大的话影响还不明显,数据量大的时就非常明显,这也是之前为什么一直没有人提这个问题(测试环境下这个问题不明显)。

posted on 2019-08-21 18:04  power_yu  阅读(784)  评论(0编辑  收藏  举报

导航