位置: 编程技术 - 正文

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)

  • 自然人独资企业有公司章程吗
  • 投资者从其投资企业借款
  • 企业所得税是什么意思
  • 视同销售是指什么
  • 商务费用报销一般有哪些流程
  • 个体营业执照从哪里查询
  • 企业缴纳的社保
  • 所得税减免优惠明细表应分摊期间
  • 计划成本法委托加工物资例题
  • 人力资源代缴社保合法吗
  • 资产处置收益结转损益
  • 折旧完的固定资产出售
  • 特殊销售方式下销售额的确定
  • 异地经营需要办什么税务手续?
  • 补交增值税如何入账
  • 建筑企业在增值税方面新出台的政策
  • 即用于一般计税又用于简易计税的固定资产抵扣
  • 纳税人拒不缴滞纳金是否可单独强制执行
  • 长期待摊费用以后怎么摊销
  • 往年计提有误 跨年处理
  • 数量和单价的乘积
  • 定额备用金的账务怎么做
  • 事业单位洗车费如何入账
  • 已收发票是什么意思
  • win10夜间模式怎么打开不了
  • 不具备生产条件的生产经营单位
  • mac 系统查看
  • 生产企业出口退税全部流程
  • win10应用商店下载微信
  • 材料明细账的登记范本手写
  • CodeIgniter扩展核心类实例详解
  • 销售金额环比
  • mybatis isnotempty标签
  • yolov3目标检测
  • php 截断
  • rf-kill
  • mkdir命令怎么用
  • 什么叫坏账准备
  • 本期到期债务计算公式
  • 基础的数据类型
  • 织梦网站怎么添加关键词
  • div不规则排版
  • 职工食堂费用计入哪个科目
  • 盈余公积和资本溢价
  • 费用的分摊要注意什么
  • 新准则职工福利费包括哪些
  • 开的票比实际支付的多,账务怎么处理
  • 疫情期间上班,公司是否给员工买保险
  • 新成立公司如何报税
  • 计提环保税的会计分录
  • 购进材料无发票会计分录
  • 建筑企业工程管理部职责
  • 小规模纳税人申请一般纳税人流程
  • sqlserver CONVERT()函数用法小结
  • Mysql 5.7.19 winx64 ZIP Archive 安装及使用过程问题小结
  • 在mac上如何使用微信
  • windows预览版和正式版区别
  • os x yosemite10.10.5怎么样?os x yosemite10.10.5公测版下载地址
  • linux的ftp命令
  • .exe是什么软件
  • 禁用windows installer没有用
  • mac屏幕显示设置
  • ubuntu 命令行修改用户密码
  • linuxzen
  • centos libcrypto.so.1.0.0
  • 红帽企业版更新了吗
  • win7待机时间在哪调
  • ExtJS 2.0实用简明教程 之ExtJS版的Hello
  • 炉石传说开发人员卡牌
  • gridview添加数据
  • unity learn premium
  • javascript编辑工具
  • node.js 10实战
  • unity ulua
  • js继承的方式
  • javascript精度问题的原因
  • python import ssl
  • 平谷大集时间表2022
  • 增值税差额征税什么意思
  • 重庆税务局app下载官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设