zoukankan      html  css  js  c++  java
  • 类型化dataset分页

    SELECT TOP (@每页行数)
    所选列
    FROM 表名
    WHERE (主键 NOT IN(
    SELECT TOP ((@页数-1)*@每页行数) 主键
    FROM 表名
    where (

    条件
    )))
    AND (
    条件
    )

    带排序的:

    SELECT TOP (@每页行数) 
    所选列
    FROM 表名
    WHERE (主键 NOT IN( 
    SELECT TOP ((@页数-1)*@每页行数) 主键
    FROM 表名
    where (

    条件
    )order by 排序字段 desc

    ))
    AND (
    条件
    )order by 排序字段 desc

    另外:

    一张有group by后可能很多重复行,这时用not in等基于唯一列的分布算法会存在问题。
    我的解决办法是:
    一张表有一个id int的主键,对其它列进行group by,分页思想是:把max(id)做group by后的唯一列,还是用not in的分布思想。

    GROUP BY和ORDER BY同时存在的情况是,ORDER BY对GROUP BY后的结果再进行排序的,所以ORDER BY后面的排序字段需要在SELECT里出现的。

    还有:表里面没有主键时:

    WHERE (主键 NOT IN( 
    SELECT TOP ((@页数-1)*@每页行数) 主键

    部分的主键可以为:字段1+字段2,然后:

    order by 排序字段

    的排序字段为:字段1,字段2

  • 相关阅读:
    9.17(day11)
    9.14(day10)
    9.13(day9)
    9.12(day8)
    mysql 的存储过程
    MySQL 子查询与多表联合查询
    MySQL 函数
    MySQL 的查询
    MySQL的约束
    MySQL 表的增删改查操作
  • 原文地址:https://www.cnblogs.com/albert1017/p/3519886.html
Copyright © 2011-2022 走看看