在特定情况下使用游标改善语句执行效率

ZDNet软件频道 时间:2009-12-03 作者: | 赛迪网 我要评论()
本文关键词:Server 服务器 SQL
【赛迪网-IT技术报道】正常情况下,游标都不如sql语句快,但是笔者碰上一个3千万级的表设置为表a,还有一个几万级的表设置为表b,从表b提取前600,每组取前10个。大家可以发现,执行效率很糟糕,执行了几分钟后,如果改用游标加top 10则只会用2秒的时间。

  【赛迪网-IT技术报道】正常情况下,游标都不如SQL语句快,但是笔者碰上一个3千万级的表设置为表a,还有一个几万级的表设置为表b,从表b提取前600,每组取前10个。

  如果用SQL语句写的话,与下面的语句类似:

  select

  t.*

  from

  表 t

  where

  t.declid in(select top 10 declid from 表 where a列=t.a列)

  大家可以发现,执行效率很糟糕,执行了几分钟后,如果改用游标加top 10则只会用2秒的时间。

Server

服务器

SQL


百度大联盟认证黄金会员Copyright© 1997- CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号 京ICP备09041801号-159
京公网安备:1101082134