位置: 编程技术 - 正文

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

  • 一般纳税人开普票税率是3%还是13%
  • 未交增值税借贷方负数表示
  • 纳税检查调整的滞纳金怎么收
  • 增值税抵扣了还能作废吗
  • 增值税存量和增量留抵退税
  • 注册税务师的报名条件、时间及考试
  • 用友T3资产负债表公式
  • 金三财务报表如何更正
  • 台账和明细账的区别
  • 邀请境外机构提出申请
  • 个税专项扣除需要提供哪些依据
  • 报销业务招待费用主题
  • 上期计提的费用是什么
  • 固定资产转在建工程
  • 发给职工的福利要交个税吗
  • 房屋出租要交产证吗
  • 土地价值是否计入GDP
  • 高亮!这些发票不能抵扣增值税
  • 利润表本月金额指的是什么
  • 环境工程开票多少税率
  • 用银行存款缴纳上月所得税分录
  • 房地产企业已预缴增值税如何抵扣
  • 商品残次品怎样定义
  • 收到别的公司对公转账往来
  • rpcclient.exe - rpcclient是什么进程 有什么用
  • PHP 中 Orientation 属性判断上传图片是否需要旋转
  • 未分配利润转增股本交印花税
  • 税前扣除凭证管理办法第九条称小额零星支出是
  • 房产税缴纳标准是多少
  • 体积最小的u盘
  • nvidia显卡驱动怎么安装
  • 交暖气费可以开单位发票吗
  • 落基山国家公园攻略
  • 可供出售金融资产和交易性金融资产
  • 林木业折旧年限
  • 所得税减免要做账吗
  • 【Spring+SpringMVC+Mybatis】Spring+SpringMVC+Mybatis实现前端到后台完整项目
  • 以无形资产向外单位投资会引起会计要素
  • 固定资产盘盈、盘亏的账务处理?
  • 裁员补偿金如何合理避税
  • 收到股利的会计分录
  • 金融债券的利息不计复利不能提前支取
  • 小规模纳税人是小微企业吗
  • macos添加用户
  • 股权转让怎么做账
  • 收到退回的增值税,应当作为营业外收入核算对吗
  • 银行存款日记账填写样本图
  • 没有收到房租发票
  • 用白纸写的收据怎么入帐?
  • 营改增账务处理实例
  • 当月销售次月开票成本怎么结转
  • 资本公积只能转现金吗
  • 企业建账选择什么会计准则
  • mysqlpid文件没有
  • 远程连接局域网内的电脑
  • 获取方法
  • boot process
  • linux怎么切到桌面
  • win8.1删除所有内容并重新安装
  • win8小键盘怎么打开
  • linux系统主要用途
  • usb转串口的接线方法
  • win8.1如何快速启动
  • cocos2dx AudioEngine初体验,音效播放结束判断测试
  • 高通umb
  • opengl 画线
  • jquery如何给div属性赋值
  • opengl es3.0
  • opengles入门
  • 不宜用于
  • 脸部两旁的骨头
  • 基础的重要性
  • js浏览器运行机制
  • 中国纳税大户排行
  • 天津地税局网上营业厅
  • 江苏税务个税查询
  • 从国外买东西回来卖
  • 铁西区地税局电话多少
  • 国税系统如何变更财务负责人
  • 上海疫情租房金额怎么算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设