位置: 编程技术 - 正文

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)

  • 小微企业税收优惠政策2023年房产税
  • 小规模纳税人附加税减免政策2023
  • 销项减进项余额在哪方
  • 规划设计合同需要缴纳印花税吗为什么
  • 房产评估费会计分录
  • 公司年会聚餐的简短讲话
  • 货款尚未收到用什么记账凭证
  • 关于处置固定资产的请示
  • 装修公司怎么交钱
  • 合同签了发票开了钱没给怎么办
  • 机构信用代码证是三证合一里的吗
  • 6种个人所得税违规手段,财务人再小心别跳坑!
  • 含税价标志有无影响
  • 小额零星业务上限是多少
  • 个人汽车贷款所购车辆
  • 境外受控公司
  • 报销时可以一个人报销吗
  • 超市买的日用品没消毒直接用
  • 苹果7充电设置在哪里
  • 小规模纳税人的增值税怎么算
  • 苹果屏幕刷新率120hz的机型
  • 销售预付款会计分录
  • 成本费用包括什么项目
  • php 递归函数
  • 企业注销后账上有结余怎么办
  • 固定资产未提完折旧停止经营怎么处理
  • replace.exe进程
  • 分包工程的税金怎样处理
  • 期票是不是承兑汇票
  • 辅导期纳税人注意事项
  • 工程未审计资金能支付到多少
  • 缴纳增值税的会计处理方法
  • 企业清算时
  • 多表联动查询
  • php引用传值
  • 服务业的增值税
  • 微服务springboot结构
  • c语言设计酒店管理系统
  • 高效刷题app
  • db2 -x
  • 详解sql基础语法实验报告
  • 跨月已计入费用后收到发票
  • 建筑企业会计科目的设置及核算
  • 固定资产盘点盘什么
  • 进销存有什么用
  • 库存现金错账怎么调整
  • 开银行承兑汇票需要多少保证金
  • 小规模纳税人购进商品会计分录
  • 质量问题举例
  • 财务报表中预收账款
  • 实收资本主要包括哪些
  • 金税盘忘记清卡了怎么办
  • 电话费计入什么二级科目
  • sql根据逗号分割数据
  • sql server如何重启
  • 打印机向windows发送消息
  • centos真机安装后只有lo
  • mac怎么设置应用权限
  • centos6挂载ntfs硬盘
  • 2019谷歌浏览器
  • xp系统里的打印机怎么设置的和新7
  • xp系统怎么关闭fn
  • win系统文件在哪里
  • win10 mobile 1709
  • centos安装zsh
  • win7系统修改mac地址
  • unityrpg
  • windows常用命令操作
  • python绘制球面
  • jquery 设置css
  • jQuery+Ajax实现无刷新操作
  • unity soket
  • JavaScript获取网页内容
  • js 工作流
  • jquery编写页面载入事件
  • 增值税一般纳税人和小规模纳税人的区别
  • 保险理赔款如何分配
  • 跨区域报验和预审的区别
  • 两利四率完成情况
  • 公司税务怎么查询缴款信息呢
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设