位置: 编程技术 - 正文

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)

  • 金蝶能够反年结账吗
  • 计提的坏账准备可以税前扣除吗
  • 分公司能享受小微企业所得税优惠吗
  • 社保次月缴纳上月算不算中断
  • 航天金税盘证书口令错误
  • 上一年度多计提折旧怎么调整
  • 代理记账服务内容
  • 股票收入要交所得税吗
  • 在文具公司工作怎么样
  • 外贸企业当期认证的发票没申报影响退税吗?
  • 进项发票和销项发票金额相同还需要交税金吗
  • 工程款增值税怎么算
  • 2017年7月1日通用机打发票能不能作为税收凭证?
  • 集体福利支出包括
  • 什么人可以领购房补贴怎么领取
  • 投资款需要缴纳增值税吗
  • 金税盘红字信息表金额大于原蓝票
  • 股权无偿赠与子女怎么办理手续
  • 企业增速怎么算
  • 收到往来款的账务处理
  • 公司商品房出售流程
  • 存货跌价准备可以转回吗?
  • 现金流量表的计算公式原理
  • 即征即退的增值税需要缴纳企业所得税吗
  • 工资薪金所得包括差旅费津贴吗
  • 零申报 社保
  • 常见的无线网络技术有
  • 代垫费用的进项税怎么算
  • 企业的往来账款包括哪些
  • 年末进公司有年终奖吗
  • 详解HTTP Cookie状态管理机制
  • 会计月报表怎么做表格
  • pdf在线预览备注
  • vue实战开发项目视频
  • timit数据集
  • clh锅
  • b站导出预设
  • 匈牙利算法的实现原理
  • 广告费与业务宣传费范围
  • 无标题节啥意思
  • 一学就会的人是天才吗
  • 什么是男人无力的行为
  • php的序列化操作生成的哪种格式
  • html5 function
  • 应交税费的主要成本
  • 往来款的意思
  • dede织梦怎么转成zblog
  • 营改增后房地产开发税费一览表
  • 企业投资收益要交增值税吗
  • 减值准备为什么不影响影响资产余额
  • 金税四期上线后如何查虚开
  • 增量留底退税额计算
  • 增值税的预缴税怎么算
  • 公司组织员工吃饭或举行活动的行为被称为什么
  • 材料估价入库发票收到如何记账
  • 新公司第一次报税需要准备什么
  • 视同内销账务处理怎么做?
  • 汇算清缴所得税的账务处理会计分录
  • 个人所得税税前扣除凭证
  • 与成本直接相关的有哪些
  • 私人网银可以转账吗
  • 商业银行的固定资产
  • sqlserver 索引
  • Mysql使用or如何优化
  • xp系统如何安装
  • freebsd版本选择
  • linux系统添加新用户
  • window10怎么升11
  • win7控制面板找不到windows update
  • win8切换到桌面的快捷键
  • 快捷方式栏在哪
  • js 单引号
  • unity获取鼠标点击的位置
  • unity3d总结
  • 使用jquery实现的项目
  • jquery.form.js实现文件上传
  • Cannot run program "/home/mohemi/Program/adt-bundle-linux-x86_64-20130729/sdk//tools/emulator": erro
  • 注册财税公司需要什么条件
  • 云南国税局官网网站
  • 广州财务顾问公司
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设