位置: 编程技术 - 正文

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

  • 境外代扣代缴增值税
  • 折扣方式销售货物增值税
  • 增值税专用发票是干什么用的
  • 银行回单可以跨年补录吗
  • 税控盘上报
  • 所有者投入的资本属于什么科目
  • 境外企业在境内取得的收入所得税
  • 消费取得普通发票怎么开
  • 营改增后销售不动产的收入
  • 固定资产发票未到怎么提折旧
  • 法的分级
  • 物流公司开票税率
  • 广告制作费怎么入账
  • 个人购买余额宝安全吗?
  • 现金采购怎么算
  • 离婚后房产过户需要多少钱
  • 酒店兼营行为的税务处理?
  • win10系统怎么永久激活
  • 出口退税率为0%退税收入怎么算
  • 开办费属于什么科目类别
  • 个税申报的人数比工资表少了怎么办
  • 应付职工薪酬账户结构
  • 残疾人保障金汇算清缴填在哪里
  • 房屋出租后土地使用税谁来交
  • os线程是什么
  • PHP:Memcached::setMulti()的用法_Memcached类
  • 小规模纳税人销售商品会计分录
  • Win11 Build 22449.1000 预览版发布(附更新修复已知问题汇总)
  • 冲减其他应收款摘要怎么写
  • 劳务报酬所得缴纳时间
  • 境外服务收入如何申报增值税
  • 科尼西卡神庙在哪里
  • 机关事业单位购买茶叶违反什么规定
  • 小规模纳税人开专票需要交税吗
  • 一键部署源码
  • 小说《从零开始》
  • js获取本机ip地址
  • 煤炭贸易公司的业务流程
  • 油气勘探开发
  • 跨境电商企业账务如何做账
  • python中的列表和元祖有什么区别
  • springcloud分布式微服务组件
  • 保单的增值税发票能抵税吗
  • 辞退福利为什么不计入产品成本
  • 企业所得税季报人数季度初值
  • sqlserver降级备份
  • 关税完税价格计算增值税
  • 水利建设基金计费方式
  • 农产品收购进项税抵扣会计分录
  • 限定性净资产的例子有哪些
  • 股东分派现金股利怎么算
  • 公司控股的子公司 法人能被追加吗
  • 小规模现金流量表年报不填可以吗
  • 手机发票计入什么科目
  • 接受慈善捐款结尾怎么写
  • 建筑工程合同中社保基金保证金
  • 两家公司
  • 重要性水平如何判断
  • 新公司成立建账流程
  • sql做判断
  • win8系统怎么设置投屏
  • 从几个方面论述
  • Windows8.1和Ubuntu14.04双系统卸载Ubuntu的方法
  • windows预览版和正式版区别
  • win10快速操作怎么调出来
  • centos7修改文件内容
  • windows time同步系统时间的服务无法启动报错1058解决方法
  • 文件夹底部显示
  • cocos设计模式
  • nodejs项目开发
  • css盒子模型示意图
  • sort 函数
  • jquery-easyui-1.3.3
  • javascript中checkbox使用方法简单实例演示
  • 全面解析白羊座o型血女
  • Python判断字符串结尾并输出yes或no
  • 河南省国家税务局通用定额发票
  • 新疆地方税务局
  • 企业改制和重组的区别
  • 小船载重多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设