sqlserver 多表关联时在where语句中慎用trim()方法


类似如下:

select A.key,B.key,C.key from A,B,C where trim(A.key)=trim(B.fk) and trim(A.col)=trim(C.pk)。

在主表A(200多条记录)关联附表B(4万多条记录)时用了1秒钟时间,该值在不同机器执行可能有所差异,但比不加trim速度稍微慢一些,但是不是特别明显。

其sql语句类似如下:

select A.key,B.key from A,B where trim(A.key)=trim(B.fk)

但是,在上面sql语句中加入第三个表C(两条记录)后,Sql语句如下:

select A.key,B.key,C.key from A,B,C where trim(A.key)=trim(B.fk) and trim(A.col)=trim(C.pk)

整个sql语句执行了差不多70多秒钟。比不加trim()方法多发费了60夺秒。

后来,通过若干实验发现这种where中多表关联条件,如果不在左边关联条件处加trim()方法即可达到基本等同于一般多表关联的效率。

改良后的sql语句如下:

select A.key,B.key,C.key from A,B,C where A.key=trim(B.fk) and A.col=trim(C.pk)

此条sql语句执行效率基本等同于where语句中无trim()的sql语句速度了。



相关阅读:
让的PHP代码飞起来的40条小技巧(提升php效率)
JavaScript this 深入理解
Ajax跨域代理访问网络资源的实现代码
javascript移动的盒子效果代码
JS 俄罗斯方块完美注释版代码
linux下txt格式文本转换成xls表格
Web代理(Asp版)
好东西,老外用正则表达式写的HTML分离函数
用winrar定时压缩备份文件
CSS教程:彻底弄清楚CSS的行高属性
解析PayPal支付接口的PHP开发方式
对字符串进行HTML编码和解码的JavaScript函数
聊天室php&mysql(六)
jQuery 美元符冲突的解决方法
快速导航

Copyright © 2016 phpStudy |