位置: 编程技术 - 正文

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)

  • 年终奖怎么计税的
  • 企业所得税几大税种
  • 付款后发票可以抵扣吗
  • 个人独资企业可以核定征收吗
  • 印花税退税流程怎么操作
  • 拓展费税收分类编码
  • 增值税专用发票电子版
  • 公司现金支付管理办法
  • 子公司固定资产移到母公司
  • 向个人借款计入什么会计科目
  • 固定资产到期怎么处理
  • 资产负债表的编制方法和步骤
  • 小规模跨年发票可以入账吗
  • 因质量问题怎么赔偿
  • 股东转账实收资本怎么填
  • 自行建造固定资产的计税基础
  • 房地产行业零税率发票
  • 已经入账的发票能把原始票据退回吗
  • 房地产企业增值税预缴
  • 旅游业税率是多少,企业税是按季度缴纳吗
  • 出口退免税是什么意思
  • 企业经营者试行什么制度
  • 进项和销项的会计分录
  • 没有签订合同需要申报印花税吗
  • 其他权益性无形资产的进项税额抵扣
  • 发放给职工
  • 借用别人的公司经营
  • 企业发生的培训费能否在所得税前扣除
  • PHP:oci_result()的用法_Oracle函数
  • linux shell语句
  • 电脑每次开机都要选择系统怎么办
  • 银河麒麟操作系统价格
  • 法罗群岛知乎
  • 鱼香肉丝的做法的教程
  • 奥林匹克国家公园
  • 股权置换和股权转让
  • 增值税发票查询结果不一致是什么意思
  • php解析base64数据生成图片的方法
  • gnss定位技术的应用前景
  • which 查找文件
  • 织梦cms官网
  • 生产车间发生的费用计入什么科目
  • 银行汇票是什么意思易懂
  • 个体升一般纳税人的界限
  • 房地产企业政府返还款
  • 设备服务费
  • 计提工会经费会计凭证怎么做分录
  • 外地预缴税款如何查询
  • 债券清算原则
  • 住房基金可以取出来用吗
  • 代收开票收入怎么做账
  • 以前年度费用科目入错 不影响以前年度利润的账务处理
  • 发票 发票专用章
  • 银行存款明细账借方代表什么
  • 企业和债权人有什么利益冲突
  • wind如何安装
  • 如何在mac上保存文件
  • ubuntu作为开发环境
  • ddriver进程
  • linux xim
  • openssh教程
  • opengl 模型
  • javascript中的eval函数
  • 激情台球游戏源码大全
  • perl语句
  • jquery拖拽功能
  • python中matplotlib绘制曲线
  • javascript 中的事件委托详解
  • csm support
  • 在unity中单例的主要作用
  • python 生成器send
  • 从零开始学什么好
  • node.js怎么用
  • javascript怎么学
  • android PopupWindow显示位置设置
  • unity优化技巧
  • 电子税务局校验码
  • 深圳罗湖区公安局长安慧君简历
  • 纳税服务的背景是什么
  • 房产折旧怎么算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设