位置: 编程技术 - 正文

mysql中索引与FROM_UNIXTIME的问题(mysql中索引有什么用)

编辑:rootadmin

推荐整理分享mysql中索引与FROM_UNIXTIME的问题(mysql中索引有什么用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:索引 mysql,mysql 索引 or,mysql的索引有,MySQL中索引与约束,mysql索引什么意思,mysql 索引语句,mysql 索引语句,mysql的索引有,内容如对您有帮助,希望把文章链接给更多的朋友!

零、背景

这周四收到很多告警,找DBA看了看,发现有个慢查询。

简单收集一些信息后,发现这个慢查询问题隐藏的很深,问了好多人包括DBA都不知道原因。

一、问题

有一个DB, 有一个字段, 定义如下.

索引如下:

然后我写了一个SQL如下:

终于有一天DBA过来了, 扔给我一个流水,说这个SQL是慢SQL。

我顿时无语了,我的DB都是加了索引,SQL都是精心优化了的,怎么是慢SQL呢?

问为什么是慢SQL,DBA答不上来, 问了周围的同事也都答不上来。

我心里暗想遇到一个隐藏很深的知识点了。

令人怀疑的地方有两个:1.有6个索引。 2. 右值是 FROM_UNIXTIME 函数。

mysql中索引与FROM_UNIXTIME的问题(mysql中索引有什么用)

于是查询MYSQL官方文档,发现6个不是问题。

All storage engines support at least indexes per table and a total index length of at least bytes. Most storage engines have higher limits.

于是怀疑问题是 FROM_UNIXTIME 函数了。

然后看看MYSQL的INDEX小节,找到一点蛛丝马迹。

1.To find the rows matching a WHERE clause quickly.2. To eliminate rows from consideration. If there is a choice between multiple indexes, MySQL normally uses the index that finds the smallest number of rows. 3.If the table has a multiple-column index, any leftmost prefix of the index can be used by the optimizer to look up rows.4. MySQL can use indexes on columns more efficiently if they are declared as the same type and size. Comparison of dissimilar columns (comparing a string column to a temporal or numeric column, for example) may prevent use of indexes if values cannot be compared directly without conversion.

看到第4条的时候,提到不同类型可能导致不走索引,难道 FROM_UNIXTIME 的返回值不能转化为字符串类型?

于是查询 FROM_UNIXTIME 函数的返回值。

MySQL FROM_UNIXTIME() returns a date /datetime from a version of unix_timestamp.

返回的是一个时间类型,那强制转化为字符串类型呢?

这次可以看到, 使用了索引,只扫描了一个数据。

二、结论

这次对 FROM_UNIXTIME 的返回值强制转化一下就可以利用上索引了。

所以这个SQL不能利用上索引是右值与左值的类型不一致导致的。 。

好了,不多说了, 这篇文章算是一个插曲,后面继续介绍算法吧。

mysql中mydumper 和 mysqldump 对比使用 如果只是备份几张表或单个库,相比innobackup而言,mysqldump和mydumper更为方便,不过mydumper增加了相对较多的特性,比如多线程备份,正则匹配备份,分组和自检等

mysql mycat 中间件安装与使用 一,什么是mycat一个彻底开源的,面向企业应用开发的大数据库集群支持事务、ACID、可以替代MySQL的加强版数据库一个可以视为MySQL集群的企业级数据库

ubuntu下在docker中安装mysql5.6 的方法 1.安装mysql5.6dockerrunmysql:5.6等所有项目都是Downloadcomplet安装完毕5.6:Pullingfromlibrary/mysqlacf:Pullcompletec2dcc7bb2a:Pullcompletee7a:Pullcomplete9aaf:Pu

标签: mysql中索引有什么用

本文链接地址:https://www.jiuchutong.com/biancheng/349379.html 转载请保留说明!

上一篇:Linux下安装配置MySQL(linux的安装)

下一篇:mysql中mydumper 和 mysqldump 对比使用(mysqldump mysqlpump)

  • 纳税调整减少额是什么意思
  • 小企业今年怎么过
  • 12月工资1月发个税怎么算
  • 银行入息是入几个月的
  • 季报利润表本期数
  • 如何确定商品交易价格?
  • 房产税按原值计算公式
  • 预付款什么时候确认收入
  • 永续债的利息会计处理
  • 没通过认证的增值税发票是否能够记入成本抵扣
  • 个体户财务负责人风险有哪些
  • 出租不动产什么时候交税
  • 交易性金融资产公允价值变动计入
  • 商业汇票收款到什么账户
  • 贷款房屋评估费怎么收
  • 处置二手固定资产
  • 减值测试的资产有哪些
  • 发票开具的法定义务是什么
  • 逾期未收回包装物押金增值税
  • 破产清算中欠发工资应否交个人所得税
  • 红字发票如何开具
  • 亏损企业所得税汇算清缴怎么做
  • init 4命令
  • php的运行环境有哪些
  • 报销人和收款人不一致
  • 企业的研发支出
  • 兼职算受雇吗
  • 正规现金收款收据怎么写
  • 申报个税是不是就必须交社保
  • 不能加计扣除的研发费用在辅助账怎么反映
  • python27文件夹
  • mongodb 聚合
  • 持有至到期投资属于流动资产吗
  • sql server 18486
  • sql server定时作业
  • sql2016异地备份
  • 商业折扣应该怎么计算
  • 房地产企业成本核算方法
  • 领用库存商品用于生产产品
  • 简易征收的纳税标准
  • 商业企业库存商品成本核算
  • 期末结转主营业务成本
  • 施工项目部主要职责
  • 固定资产如何抵扣进项税额
  • 银行收的账户管理费
  • 银行进账单需要作为附件吗
  • 固定资产抵账的账务处理
  • 出口退税转为免税做账处理
  • 红字发票怎么申报增值税
  • 核销预收账款是否需要计提增值税
  • 工业企业存货发出计价的方法
  • 商业企业费用科目
  • Windows server 2003 最后一代cpu
  • 虚拟机中安装虚拟机
  • vsftpd.service disabled
  • centos安装位置选择
  • 恢复双系统启动菜单
  • mac怎么设计网页
  • windows xp系
  • 如何解决焦虑的心理
  • 工商网银安装
  • win7桌面图标有小方块
  • cocos creator js教程
  • unity分发平台
  • androidtime
  • perl 教程
  • U3DPlayer UnityWebPlayer动态改变src
  • javascript中的107个基础知识收集整理 推荐
  • jquery添加节点
  • js asc
  • jQuery插件是什么
  • js 数组处理
  • javascript中this的用法
  • js实现类
  • 地税局书记是什么级别
  • 服务协议属于哪类合同
  • 房地产预缴土增值税
  • 佛山电子税务
  • 12345市民热线什么时候有的
  • 怎么查询公司法人电话号码
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设