数据库分页

mac2022-06-30  25

 

Mysql分页采用 limit 关键字

select * from t_user limit 5, 10; #返回第6-15行数据select * from t_user limit 5;      #返回前5行select * from t_user limit 0, 5;  #返回前5行

 

Oracle分页

 采用 rownum 关键字(三层嵌套)  

/*SELECT * FROM( SELECT A.*,ROWNUM num FROM (SELECT * FROM t_order)A WHERE ROWNUM<=15) WHERE num>=5;--返回第5-15行数据*/

/*

* firstIndex:起始索引

* pageSize:每页显示的数量

* sql:可以是简单的单表查询语句,也可以是复杂的多表联合查询语句

*/select *

from(

  select a.*,ROWNUM rn

  from(sql) a 

  where ROWNUM<=(firstIndex+pageSize)

  )

where rn>firstIndex

 

 

 

  采用 row_number 解析函数进行分页(效率更高)

/*SELECT xx.* FROM( SELECT t.*,row_number() over(ORDER BY o_id)AS num FROM t_order t )xx WHERE num BETWEEN 5 AND 15; --返回第5-15行数据 解析函数能用格式 函数() over(pertion by 字段 order by 字段); Pertion 按照某个字段分区 Order 按照勒个字段排序*/

/*

* firstIndex:起始索引

* pageSize:每页显示的数量

* orderColumn:排序的字段名

* sql:可以是简单的单表查询语句,也可以是复杂的多表联合查询语句

*/select *

from(

  select *

  from(

    select t.*,row_number() over(order by orderColumn) as rownumber

    from(sql) t

    ) p

  where p.rownumber>firstIndex

  )

where rownum<=pageSize

 

 

 

Oracle主键自增

#序列 create sequence sq_qinh minvalue 1 maxvalue 99999999999 start with 1 increment by 1 cache 2000; #触发器    create or replace trigger 触发器名字 before insert on 表名 for each row declare -- local variables here begin SELECT sq_1.nextval INTO :NEW.列名 FROM DUAL; end 触发器名字;sql语句 insert into gd(id) values(sq_qinh.nextval)  

 

转载于:https://www.cnblogs.com/QinH/p/4736918.html

相关资源:SQLServer数据库分页查询
最新回复(0)