今天看到一条用函数处理连接的SQL,是群里某位网友的,SQL语句如下:

SELECT SO_Order.fdate ,  SO_Order.fsnFROM so_order  INNER JOIN so_orderitem ON CHARINDEX(so_Orderitem.fid, SO_Order.fid) >= 1WHERE so_order.FOrderDate = '2015-09-06'

--1.SQL执行203条数据

--2.耗时12秒

--3.so_order表的fid字段是字符串集合,

--由1-2个字符串组成,用','分隔

SELECT COUNT(*)FROM SO_OrderWHERE so_order.FOrderDate = '2015-09-06'--24SELECT COUNT(*)FROM so_Orderitem--414154

扫描上。因此,我们要通过改写SQL,达到so_orderitem走索引查找的目的。

  将so_order表的fid字段拆分成2个字段,然后union all成一个结果集,再和so_orderitem关联,即可让so_orderitem表走索引查找。

改写的SQL如下:

;WITH x0   AS ( SELECT fdate ,      fsn ,      LEFT(fid, CASE WHEN CHARINDEX(',', fid, 1) = 0 THEN 0          ELSE CHARINDEX(',', fid, 1) - 1         END) AS fid    FROM  so_order    WHERE FOrderDate = '2015-09-06'    UNION ALL    SELECT fdate ,      fsn ,      RIGHT(fid, LEN(fid) - CHARINDEX(',', fid, 1)) AS fid    FROM  so_order    WHERE FOrderDate = '2015-09-06'    ) SELECT SO_Order.fdate ,   SO_Order.fsn FROM x0 so_order   INNER JOIN so_orderitem ON so_Orderitem.fid = SO_Order.fid

  改写后SQL的执行计划如下:


更多相关文章

  1. SQL Server之JSON 函数详解
  2. MySQL 5.7.9 服务无法启动-“NET HELPMSG 3534”的解决方法
  3. MySQL系列多表连接查询92及99语法示例详解教程
  4. Linux下MYSQL 5.7 找回root密码的问题(亲测可用)
  5. MySQL 什么时候使用INNER JOIN 或 LEFT JOIN
  6. Android(安卓)-- Android(安卓)JUint 与 Sqlite
  7. Android(安卓)初识Retrofit
  8. android中SqLite query中用selectionArgs处理字符传值
  9. android从服务器下载文件(php+apache+win7+MySql)

随机推荐

  1. LeetCode #27 移除元素
  2. 以B站C语言视频为基础的课后总结(一)
  3. LeetCode #26 删除排序数组中的重复项
  4. 排序算法 #5 归并排序
  5. 来自Kenneth Reitz大神的建议:避免不必要
  6. 满满的一篇,全是复杂度分析核心知识点
  7. LeetCode #80 删除排序数组中的重复项II
  8. 再聊聊Python中文社区的翻译
  9. Python对象的身份迷思:从全体公民到万物皆
  10. 数据结构 #2 36张图带你深刻理解链表