SQL参数化出现执行慢问题

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

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

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

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

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

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

猜你喜欢

转载自www.cnblogs.com/power-yu/p/11390310.html