PostgreSQL 分页查询时间的2种比较方法小结
数据库中存了3000W条数据,两种分页查询测试时间
第一种
SELECT * FROM test_table WHERE i_id> 1000 limit 100;
Time: 0.016s
第二种
SELECT * FROM test_table limit 100 OFFSET 1000;
Time: 0.003s
第一种
SELECT * FROM test_table WHERE i_id> 10000 limit 100;
Time: 0.004s
第二种
SELECT * FROM test_table limit 100 OFFSET 10000;
Time: 0.508s
第一种:
SELECT * FROM test_table WHERE i_id> 100000 limit 100;
Time: 0.003s
第二种:
SELECT * FROM test_table limit 100 OFFSET 100000; Time: 2.377s SELECT * FROM test_table WHERE c_act='登录' limit 100 OFFSET 100000; Time: 3.649s
第一种:
SELECT * FROM test_table WHERE i_id> 1000000 limit 100;
Time: 0.004s
第二种:
SELECT * FROM test_table limit 100 OFFSET 1000000;
Time: 14.403s
第一种:
SELECT * FROM test_table WHERE i_id> 10000000 limit 100;
Time: 0.057s
第二种:
失去等待出来结果的耐心!!!
建议使用第一种分页方法~
补充:postgreSQL数据库limit分页、排序
limit分页语法:
select * from persons limit A offset B;
解释:
A就是你需要显示多少行;
B就是查询的起点位置。
示例:
select * from persons limit 5 offset 0 ;
意思是,起点0开始查询,返回5条数据。
select * from persons limit 15 offset 5 ;
意思是,起点5开始查询,返回15条数据。
特殊:
select * from persons limit 5 ;
这个就类似:
select * from persons limit 5 offset 0;
也就是,从起点0开始查询,返回5条数据。
按规则排序,同时也要分页:
select * from persons order by lastname limit 5 offset 0;
分页并显示行号,类似oracle里的rownum:
select *,row_number() over() as rownum from persons limit 5 offset 0;
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。如有错误或未考虑完全的地方,望不吝赐教。
相关推荐
-
postgresql rank() over, dense_rank(), row_number()用法区别
如下学生表student,学生表中有姓名.分数.课程编号,需要按照课程对学生的成绩进行排序 select * from jinbo.student; id | name | score | course ----+-------+-------+-------- 5 | elic | 70 | 1 4 | dock | 100 | 1 3 | cark | 80 | 1 2 | bob | 90 | 1 1 | alice | 60 | 1 10 | jacky | 80 | 2 9 | iri
-
在postgresql数据库中判断是否是数字和日期时间格式函数操作
在编写GreenPlum函数的过程中,遇到要判断字符串是否是数字和日期格式的情况,基于GreenPlum和postgresql的亲缘关系,找到了下面两个函数. --1.判断字符串是否是数字 CREATE OR REPLACE FUNCTION isnumeric(txtStr VARCHAR) RETURNS BOOLEAN AS $$ BEGIN RETURN txtStr ~ '^([0-9]+[.]?[0-9]*|[.][0-9]+)$'; END; $$ LANGUAGE 'plpgsq
-
postgresql 实现sql多行语句合并一行
多行语句合并一行 三个表关联查询的结果集为: SELECT users.name,users.age,users.birthday,roles.name FROM users,users_roles,roles WHERE users_roles.userid = users.id and users_roles.roleid = roles.id name age birthday role 张三 23 1993-1-1 role1 张三 23 1993-1-1 role2 张三 23 199
-
PostgreSQL删除更新优化操作
1. 先说删除吧,因为刚搞了. 删除缓慢的原因:主要是约束的问题.(数据库在有约束的时候,进行操作,会根据约束对相关表进行验证,可想而知,20W的数据验证要耗费多久的时间).其次就是sql的编写.(sql如果查询中包含子查询等的可以优化的where会影响匹配的速度<查询的话就不多逼逼了>).索引的问题 请看下面的 补充部分 具体解决方法: ALTER TABLE tableName DISABLE TRIGGER ALL; delete 目标语句 ALTER TABLE tableName E
-
PostgreSQL 实现将多行合并转为列
需求将下列表格相同id的name拼接起来输出成一列 id Name 1 peter 1 lily 2 john 转化后效果: id Name 1 peter:lily 2 john: 实现方式使用 array_to_string 和 array_agg 函数,具体语句如下: string_agg(expression, delimiter) 把表达式变成一个数组 string_agg(expression, delimiter) 直接把一个表达式变成字符串 select id, array_to
-
Postgresql自定义函数详解
PostgreSQL函数也称为PostgreSQL存储过程. PostgreSQL函数或存储过程是存储在数据库服务器上并可以使用SQL界面调用的一组SQL和过程语句(声明,分配,循环,控制流程等). 语法: CREATE [OR REPLACE] FUNCTION function_name (arguments) RETURNS return_datatype AS $variable_name$ DECLARE declaration; [...] BEGIN < function_body
-
PostgreSQL 分页查询时间的2种比较方法小结
数据库中存了3000W条数据,两种分页查询测试时间 第一种 SELECT * FROM test_table WHERE i_id> 1000 limit 100; Time: 0.016s 第二种 SELECT * FROM test_table limit 100 OFFSET 1000; Time: 0.003s 第一种 SELECT * FROM test_table WHERE i_id> 10000 limit 100; Time: 0.004s 第二种 SELECT * FROM
-
php分页查询mysql结果的base64处理方法示例
本文实例讲述了php分页查询mysql结果的base64处理方法.分享给大家供大家参考,具体如下: public function public_about(){ $sql= "SELECTc.catid,c.catname,c.catdir,FROM_BASE64(p.content) FROM v9_page p JOINv9_category c ON c.catid=p.catid WHERE c.parentdir = 'jmwm/'"; if(isset($_REQUEST
-
基于构造函数的五种继承方法小结
1.使用call或apply绑定构造函数 animal.apply(this.arguments) 2.使用prototype属性 Cat.prototype = new Animal(); Cat.prototype.constructor = Cat; var cat1 = new Cat("大毛","黄色"); alert(cat1.species); // 动物 3.直接集成prototype属性 function Animal(){ } Animal.pr
-
对python条件表达式的四种实现方法小结
如下所示: a, b, c = 1, 2, 3 # 1.常规 if a>b: c = a else: c = b # 2.表达式 c = a if a>b else b # 先执行中间的if,如果返回True,就是左边,False是右边. # 3.二维列表 c = [b,a][a>b] #实际是[b,a][False],因为False被转换为0,所以是[1,2][0],也就是[1] # False返回第一个,Tr
-
SQL中的三种去重方法小结
目录 distinct group by row_number 在使用SQL提数的时候,常会遇到表内有重复值的时候,比如我们想得到 uv (独立访客),就需要做去重. 在 MySQL 中通常是使用 distinct 或 group by子句,但在支持窗口函数的 sql(如Hive SQL.Oracle等等) 中还可以使用 row_number 窗口函数进行去重. 举个栗子,现有这样一张表 task: task_id order_id start_time 1 123 2020-01-05 1 2
-
Python中浅拷贝的四种实现方法小结
目录 方式一:使用切片 [:] 方式二:使用工厂函数 方式三:使用数据类型自带的 copy 方法 方式四:使用 copy 模块的 copy 方法 方式一:使用切片 [:] 列表 # 浅拷贝 [:] old_list = [1, 2, [3, 4]] new_list = old_list[:] old_list.append(5) old_list[2][0] += 97 print("Old list:", old_list, "old list id:", id
-
JavaScript数组合并的8种常见方法小结
目录 1.ES6 解构 2.遍历添加 3.concat 4.join & split 5.解构添加 6.splice解构 7.apply 8.call 补充:两个数组的交叉合并 总结 1.ES6 解构 [...arr, ...array] 不改原数组值,生成新的数组. 2.遍历添加 array.forEach(item => { arr.push(item) }) 遍历方法:forEach.map.filter.every.for.for in.for of等. 添加方法:push(后追加)
-
提高MySQL深分页查询效率的三种方案
开发经常遇到分页查询的需求,但是当翻页过多的时候,就会产生深分页,导致查询效率急剧下降.有没有什么办法,能解决深分页的问题呢?本文总结了三种优化方案,查询效率直接提升10倍,一起学习一下. 开发经常遇到分页查询的需求,但是当翻页过多的时候,就会产生深分页,导致查询效率急剧下降. 有没有什么办法,能解决深分页的问题呢? 本文总结了三种优化方案,查询效率直接提升10倍,一起学习一下. 1. 准备数据 先创建一张用户表,只在create_time字段上加索引: CREATE TABLE `user`
-
mysql自动填充时间的两种实现方式小结
目录 mysql自动填充时间的两种方式 方法一:数据库级别 方式二:代码级别 mysql自动填充时间的两种方式 mysql建表的时候有两个列,一个是createtime.另一个是updatetime 当插入一条数据,createtime列和updatetime列由数据库获取当前时间自动创建时间 当修改一条记录时,updatetime列由数据库获取按当前时间自动更新时间 方法一:数据库级别 (工作中不允许你修改数据库),一般我们采用方法二 1.在表中新增字段 create_time, update
-
mysql服务器查询慢原因分析与解决方法小结
会经常发现开发人员查一下没用索引的语句或者没有limit n的语句,这些没语句会对数据库造成很大的影响,例如一个几千万条记录的大表要全部扫描,或者是不停的做filesort,对数据库和服务器造成io影响等.这是镜像库上面的情况. 而到了线上库,除了出现没有索引的语句,没有用limit的语句,还多了一个情况,mysql连接数过多的问题.说到这里,先来看看以前我们的监控做法 1. 部署zabbix等开源分布式监控系统,获取每天的数据库的io,cpu,连接数 2. 部署每周性能统计,包含数据增加量,i
随机推荐
- XML和YAML的使用方法
- Flex帮助文档(html格式)制作及ASDoc的使用
- jQuery日程管理插件fullcalendar使用详解
- Shell脚本实现自动安装zookeeper
- 在CMD下读取服务器终端的端口的代码
- 详解iOS学习笔记(十七)——文件操作(NSFileManager)
- Java实现显示指定类型的文件
- JAVA操作HDFS案例的简单实现
- asp.net反射简单应用实例
- Android编程实现ListView头部ViewPager广告轮询图效果
- 一种c#深拷贝方式完胜java深拷贝(实现上的对比分析)
- 8种android 对话框(Dialog)使用方法详解
- Android仿美团淘宝实现多级下拉列表菜单功能
- 基于MYSQL中优化的一些方法
- php中显示数组与对象的实现代码
- 实现变速回到顶部的JavaScript代码
- 浅谈NodeJS中require路径问题
- ASP.NET在线文本编辑控件的使用(第6节)
- ruby使用restclient上传服务器本地文件示例
- Select count(*)、Count(1)和Count(列)的区别及执行方式