位置: 编程技术 - 正文

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

  • 车船税每年都要交吗,一般是多少钱交强险可以晚交吗
  • 小规模纳税人专票免税吗?
  • 税金计提多了,交少了怎么处理
  • 一般纳税人应交增值税怎么算
  • 其他收益和营业收益
  • 个体户一季度不超过30
  • 做了销售之后的结果
  • 开票要交印花税吗
  • 怎么看自己公司是一般纳税人还是小规模纳税人
  • 所得税多交怎么调整
  • 公司对供应商罚款合法吗
  • 会计凭证前面放什么
  • 空白增值税专用发票丢失罚款
  • 顾客抽奖代扣个税账务处理
  • 微信提现手续费最新规定
  • 个人承包集体企业历史
  • 化肥贸易需要什么手续
  • 企业怎么申请无运输工具承运资质
  • 公司购买商业险多少钱
  • 费用一定计入当期损益吗
  • 个人转让土地使用权 增值税
  • 小微企业所得税优惠政策2023
  • 金融保险法
  • 股权激励个人所得税计算器
  • 多交附加税怎么做账
  • 高新企业认定 研发委外费用
  • 非经营性单位支出费用是什么
  • 支付水费现金流量
  • 银行保证金账务处理流程
  • win 11 bug
  • 建筑公司合作模式有哪几种
  • 苹果今天推送更新内容
  • PHP:Memcached::touch()的用法_Memcached类
  • qqlogin.exe是什么进程 qqlogin.exe应用程序错误解决办法
  • 应交增值税的会计科目怎么做
  • 车船使用税凭证还要过户吗怎么办
  • 会计交接的时候是不是有报税单
  • 嵌套if怎么用
  • 化妆品与药品
  • mac配置flutter环境变量
  • GCN经典论文笔记:Semi-Supervised Classification with Graph Convolutional Networks
  • 电子商业汇票线下清算流程
  • 开发产品的成本
  • 常见的垃圾回收器有哪些
  • sql server异常怎么处理
  • 收到个人所得税手续费返还增值税税率
  • 印花税申报时间填错造成逾期怎么办
  • 不抵扣的进项税为什么要交税
  • sql参数是什么意思
  • 车险 保险金额
  • 增值税药品发票明细
  • 零售行业的销售额由什么决定
  • 异地预缴税款少交了城建税怎么办
  • 主办会计与往来会计区别
  • 贷款担保费应计入什么
  • 小规模纳税人取得普通发票怎么做账
  • 购入固定资产会计处理
  • 资产负债表中的货币资金怎么算
  • 职工薪酬一般计入哪些科目进行核算
  • 社会保险费计提分录
  • 存货报废损失会计处理
  • 怎么理解核销
  • 在计划管理中根据事实思考这一步的内容是
  • 备用金没有发票,只有支付凭证
  • redhat rhca
  • xp开机提示explorer
  • windows8.1备份
  • linux系统如何进入终端
  • pvlsvr.exe - pvlsvr是什么进程 有什么用
  • xp更改远程端口
  • 如何判断win7
  • win10应用商店不好用
  • 双系统怎么屏蔽另一个磁盘
  • linux bye
  • cocos2d
  • 简述opengl的编程步骤
  • Unity3D&&TexturePacker
  • javascript简明教程
  • 什么是城建税的纳税义务人
  • 税票电话号码变更影响抵扣吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设