位置: 编程技术 - 正文

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

  • 转让金融商品需要缴纳增值税吗
  • 疫情期间社保单位不交个人吃亏吗
  • 营销策划代理合同
  • 汇算清缴退回的所得税
  • 会计信息采集审核需要多久
  • 工矿区城镇土地使用税
  • 委托收款结算方式流程图
  • 购进货物建不动产进项税额抵扣
  • 所得税汇算清缴补税的会计处理
  • 纳税营业额包含免税营业额吗?
  • 增值税只有销项没有进项怎么做账
  • 一般纳税人差额征税怎么做账
  • 以前年度的税务怎么查
  • 案例分析两个分公司转资金怎么做账?
  • 苗木增值税发票税率
  • 为什么营收高利润低
  • 事业单位开发成本占比
  • 三证合一之后的税务登记
  • 稿费算税
  • 企业所得税法中规定的收入总额包括
  • 个人股东分红如何合理避税
  • 投资者与被投资者的名人
  • 当期应交所得税怎么计算
  • 开票税点算什么费用
  • thinkphp3.2 layui
  • 误餐费怎么入账
  • 苹果手机抖音投屏到电视怎么投屏
  • php保存数据
  • jetson b01 a02
  • 任意盈余公积金的用途
  • 代扣代缴企业所得税账务处理
  • 公司支付员工生育津贴怎么做账
  • 建安企业开具增值税专用发票要求
  • 工行退款短信图片
  • 预缴土地增值税的税率
  • 手把手教你使用opc
  • jsp课程设计含源代码
  • node实战
  • Laravel+jQuery实现AJAX分页效果
  • 不开票销售收入怎么做账务处理
  • 季初从业人数和季末从业人数怎么填
  • 金融资产或金融负债满足下列条件之一
  • mysql慢查询日志查看
  • 固定资产怎么确认价值
  • 进项税大于销项税怎么交税
  • 车改补贴算工资吗
  • 应交税费明细账登记图
  • sqlserver2008无法连接到local用户登录失败
  • php mysql教程
  • 物业公司收的停车费做什么科目
  • 建筑业 分包
  • 投资性房地产账面价值大于公允价值计入什么
  • 开建筑工程公司赚钱吗
  • 促销有哪几个方面
  • 公司章程上的出资额怎么填
  • 计提了减值准备怎么算折旧额
  • 企业向个人借款利息如何处理
  • 发票找不到了怎么操作
  • mysql数据库sid
  • window10系统电脑配置
  • xp系统ip地址设置在哪里
  • linux的tar命令详解
  • ghost安装盘的制作
  • 如何用u盘装系统盘
  • 微软9月补丁
  • xp软件自动启动
  • creative cloud怎么用
  • 苹果电脑mac设备怎么删除
  • ControlSet001、ControlSet002以及CurrentControlSet之间有什么区别
  • Win10系统玩坦克世界不能打字怎么回事
  • 2021年win10累积更新
  • javascript函数大全
  • python 钉钉打卡定位
  • jquery动态添加和删除div
  • jquery mobile怎么样
  • 中通快递广东省内收费标准
  • 企业所得税要在几号之前申报
  • 外贸公司如何开发客户
  • 一般纳税人企业所得税怎么征收
  • 云南省2021年退休金计发基数
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设