位置: 编程技术 - 正文

探讨select in 在postgresql的效率问题(select )

编辑:rootadmin

推荐整理分享探讨select in 在postgresql的效率问题(select ),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:select into in,select into statement,select into select,select ,select include refid,select into select,select into select,select into statement,内容如对您有帮助,希望把文章链接给更多的朋友!

在知乎上看到这样一个问题:

MySQL 查询 select * from table where id in (几百或几千个 id) 如何提高效率?修改

电商网站,一个商品属性表,几十万条记录,M,索引只有主键id,做这样的查询如何提高效率?

select * from table where id in (几百或几千个id)

这些id没啥规律,分散的。。。。

看了一下答案,感觉有好多不靠谱的,但是口说无凭,所以在我的电脑上写了几个查询测试一下。我用的是Postgresql9.4,但感觉mysql应该也差不多,首先创建一个简单表,只有简单的3列,在这个问题的下面好多人提到了需要看表的大小,其实这个问题和表大小无关,只和index的大小有关,因为是index是建立在int上的,所以只和纪录数目有关。

之后生成一些随机数,Mac上用jot,Linux上用shuf

然后根据rand.file 生成查询语句:

探讨select in 在postgresql的效率问题(select <include>)

分别生成3个sql文件,in内变量的数目分别是,和个,执行这3个sql文件,看看时间

可以看到只有在in内数据到了,个的时候数据时间会有比较大的变化,但也不过是在多ms内完成。

那如果按照有些回答那样,先建一个临时表,然后用in subquery,并且希望这时候可以两表join呢?为了简单我直接用两表join了

时间如何呢?

除去drop和create的时间,依然花费了+的时间,这里的前提还是我用的ssd盘,所以写LOG的时间会快很多。为什么会这么慢呢?用explain看一下,这时候数据量较大,直接走Merge join 了

那行数据的效率如何呢?

行的数据如下:

可以看到在个值和个值的情况下create table的方式不会比直接在in里面写所有的变量好多少,explain看的话是在用NLJ了。但在数据量更大(按照原问题,这里in的数量其实无法预知)的情况下效率只会更低,再加上额外的表维护成本和多余的SQL语句,DBA肯定不喜欢的,还是相信数据库,放心大胆直接用in list来搞定这些问题吧。

以上内容是针对select in 在postgresql的效率问题,希望对大家有所帮助!

SQL Server 身份验证(Authentication) 在保密你的服务器和数据,防备当前复杂的攻击,SQLServer有你需要的一切。但在你能有效使用这些安全功能前,你需要理解你面对的威胁和一些基本的

SQL性能优化之定位网络性能问题的方法(DEMO) 最近项目组同事跟我说遇到一个SQL性能问题,他说全表只有条记录,客户端执行耗费了两分多钟,很不科学。我帮了分析出了原因并得到解决。下面小

SQL Server 里的sys.dm_exec_input_buffer的问题 我们都知道DBCC命令有点尴尬,因为你不能在T-SQL查询里调用它们,你也不能关联它们的输出到其它DMV/DMF。例如你想为每个用户会话返回最后一个执行的S

标签: select

本文链接地址:https://www.jiuchutong.com/biancheng/312909.html 转载请保留说明!

上一篇:SQL Server 2012 安全概述(sqlserver2012安装好了桌面没有图标)

下一篇:SQL性能优化之定位网络性能问题的方法(DEMO)(sql效率优化)

  • 隔月发票退回应该如何操作
  • 出租固定资产的折旧额是什么意思
  • 盘亏的设备按正常报废处理是否符合会计制度要求
  • 无销项税额
  • 专用发票二维码压线
  • 雇佣退休人员工伤赔偿标准
  • 中小企业怎么避税
  • 预收账款年底要确认收入吗
  • 受托加工物资产包括哪些
  • 以前年度已交增值税额
  • 商业保险可以税前全额扣除吗?
  • 水利基金按含税还是不含税申报
  • 2017年7月1日开始实施的税法新规
  • 防伪税控开票系统SOAP服务端
  • 怎么在电子税务局变更财务负责人
  • 孵化器虚拟地址多少钱一个啊
  • 一般纳税人购进原材料支付的增值税
  • 购销合同印花税按70%
  • 商业承兑到期兑不出来多久的追诉期
  • 新装的电脑开机慢是什么原因
  • 插上u盘电脑无法访问怎么办
  • linux zen3
  • 音量图标不显示怎么回事
  • 微信获取用户id失败如何解决
  • linux文件管理与常用命令实验报告
  • php数组函数输出《咏雪》里有多少"片"字
  • 房地产企业增值税怎么计算
  • Linux系统怎么配置IP
  • gcasSWUpdater.exe是什么进程 有什么作用 gcasSWUpdater进程查询
  • 福利性分配举例
  • 是谁唤醒你
  • form表单使用
  • 怎么计提企业所得税
  • 本年利润怎么结转到未分配利润分录
  • yolov5训练自己的模型配置到单片机
  • 企业报表年报
  • 年初结转增值税怎么算
  • 已申报营业税未开发票
  • sa密码不满足强密码要求
  • 企业取得投资收益要交税吗
  • 本月没开票还需要上报汇总吗
  • 产品出口认证
  • 股东之间股权转让的税务处理
  • 投标保证金以现金形式转为履约保证金
  • 免费给人一些客户资料违法吗
  • 非流动资产基金借贷方表示
  • 培训机构账务处理
  • 工程施工借贷方向
  • 当月开通的业务当月能取消吗
  • 通行费发票电子化 机场路
  • 注销股本对所有股票影响
  • 会计账户分类是什么意思
  • 专用发票账目不对怎么办
  • Windows 8.1下MySQL5.7 忘记root 密码的解决方法
  • mysql中怎么修改数据
  • xp系统安装版如何安装
  • windowsxp文件
  • ubuntu chsh
  • centos6.10安装教程
  • winkey.exe - winkey是什么进程
  • windows设置tomcat自动重启
  • win10一年更新一次
  • win8系统怎么关闭屏保
  • linux中mnt
  • RedHatLinux AS3中APACHE+SendMail+OpenWebMail整合
  • linux vmware命令行
  • Bullet(Cocos2dx)之凸多面体形状和组合形状
  • node javascript
  • jquery理解
  • node .js
  • js中的?
  • java 同步方法和同步代码块区别
  • python strip函数作用
  • python 脚本
  • 国税局发票查验平台查询不到
  • 小规模纳税人开3%专票怎么交税
  • 对超市的建议和意见怎么写简短
  • 外贸公司销售额可以10亿以上吗
  • 国,地税纳税申报表是什么
  • 北京朝阳国家税务总局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设