位置: 编程技术 - 正文

探讨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效率优化)

  • 大行建筑有限公司分公司
  • 成本收入不配比的风险有哪些
  • 公司会计制度由小企业会计准则改为企业会计准则怎么做
  • 减半征收附加税会计分录
  • 购买虚开增票怎么处理?
  • 租房免租是什么意思
  • 抵缴以前年度所得税怎么做?
  • 技术服务从哪年开始实施
  • 本期免税收入是什么
  • 公司为职工购买社保只购买三险可以吗
  • 商砼税率是多少
  • 个体工商户的专票可以抵扣吗
  • 公司注销 缴税
  • 苹果助手hi
  • 建筑企业收到预收账款要交增值税吗
  • 遗失发票如何处理好
  • windows history命令
  • win10我无法更改某些设置
  • windows11测试版升级正式版
  • Yosemite使用技巧 如何使用Yosemite mac信息功能共享电脑屏幕教程
  • 电脑开机时出现用户账户控制提示
  • 失控发票的企业如何处理
  • mac怎么隐藏app
  • 其他应付款余额在借方表示什么意思
  • 资产减值损失结转
  • 衍生金融资产会计科目
  • 简述php操作mysql数据库的基本步骤
  • 持有至到期投资科目被取消了吗
  • 非正常损失如何处理
  • 公司租房子 房东让我们代缴税
  • php不能通过浏览器运行吗
  • php获取网页所有页数
  • 程序员未来会失业吗
  • 大语言模型集成工具
  • python 如何
  • phpcms二次开发教程
  • python mad
  • sqlserver2005属于
  • 实缴资本需要存放多久
  • 新公司第一年年度总结
  • 普通发票的金额包含增值税吗
  • 增值税附加税的税收优惠政策
  • 公司的车过户到个人名下需要什么手续
  • 善意取得增值税专用发票所得税
  • 银行卡定期存款怎么取出来
  • 调整以前年度所得
  • 咨询费开发票应该选哪一项?
  • 协会会费怎么入账
  • 账户利息计入什么科目
  • 滴滴普通发票
  • 油票抵税能抵多少
  • 银行汇票和银行本票区别图解
  • 土地属于固定资产吗 会计
  • mysql 授权命令
  • windows server 2008文件共享服务器
  • unix系统什么样子
  • 视频对比度饱和度亮度最佳值
  • centos 安装教程
  • win8系统怎么搜索文件
  • win8怎么更改账户名称
  • win7激活工具怎么使用
  • win7系统c盘占用空间大
  • win7系统迁移到另一磁盘
  • win 10 build
  • windows10 禁用u盘
  • 2015.3.25--2.cocos精灵移动 动画控制(一)
  • cocos2dx入门
  • css div高度填满父容器剩余空间
  • opengl learn
  • android 生成图片
  • android注册界面设计
  • shell监控进程
  • unity 技术
  • shell脚本实际运用
  • Unity3D中的事件处理
  • 工具类别怎么填写
  • JavaScript charCodeAt方法入门实例(用于取得指定位置字符的Unicode编码)
  • 善意取得的条件和效力
  • 个人所得税税率怎么算
  • 天津市河东区税务局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设