小付博客

无话可说...

您现在的位置是:首页>技术分享>sqlservice 分页查询语句分析

sqlservice 分页查询语句分析

发布时间:2017-06-07 编辑:小付 浏览(522) 评论(0)

    第一种方案、最简单、普通的方法:


    代码如下:

    SELECT TOP 30 * FROM ARTICLE WHERE ID NOT IN(SELECT TOP 45000 ID FROM ARTICLE ORDER 
    BY YEAR DESC, ID DESC) ORDER BY YEAR DESC,ID DESC

    平均查询100次所需时间:45s

    第二种方案:


    代码如下:

    SELECT * FROM (SELECT TOP 30 * FROM (SELECT TOP 45030 * FROM ARTICLE ORDER BY YEAR 
    DESC, ID DESC) f ORDER BY f.YEAR ASC, f.ID DESC) s ORDER BY s.YEAR DESC,s.ID DESC

     平均查询100次所需时间:138S

    第三种方案:


    代码如下:

    SELECT * FROM ARTICLE w1, 
    (
        SELECT TOP 30 ID FROM 
        (
            SELECT TOP 50030 ID, YEAR FROM ARTICLE ORDER BY YEAR DESC, ID DESC
        ) w ORDER BY w.YEAR ASC, w.ID ASC
    ) w2 WHERE w1.ID = w2.ID ORDER BY w1.YEAR DESC, w1.ID DESC

     平均查询100次所需时间:21S

    第四种方案:

    代码如下:

    SELECT * FROM ARTICLE w1 
        WHERE ID in 
            (
                SELECT top 30 ID FROM 
                (
                    SELECT top 45030 ID, YEAR FROM ARTICLE ORDER BY YEAR DESC, ID DESC
                ) w ORDER BY w.YEAR ASC, w.ID ASC
            ) 
        ORDER BY w1.YEAR DESC, w1.ID DESC

       平均查询100次所需时间:20S

    第五种方案:


    代码如下:

    SELECT w2.n, w1.* FROM ARTICLE w1, (SELECT TOP 50030 row_number() OVER (ORDER BY 
    YEAR DESC, ID DESC) n, ID FROM ARTICLE ) w2 WHERE w1.ID = w2.ID 
    AND w2.n > 50000 
    ORDER BY w2.n ASC

    平均查询100次所需时间:15S

    查询第1000-1030条记录


关键字词:sql,sqlservice,分页