位置: 编程技术 - 正文

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)

  • 收到汇算清缴退回企业所得税分录
  • 个人独资企业生活费用和经营费用混在一起的
  • 非员工私车公用怎么进行账务处理
  • 已认证的发票如何转出
  • 个人社保部分公司承担可以入费用吗
  • 待处理财产损益借贷方向
  • 盈余公积发放现金股利分录怎么写
  • 生产车间财产保险费计入什么费用
  • 普通发票金额和申报工资有关系吗
  • 小型企业利润表
  • 股票投资收益是指投资者从购入股票开始到出售为止整
  • 结构性存款质押 叫停
  • 不动产在建工程使用的外购物资可以抵扣吗
  • 折扣为负数是什么意思
  • 应付职工薪酬账务处理例题
  • 私人企业的资金来源
  • 税金是否可以不计提呢?
  • 预警税负率表
  • 开票为单位 收款为个人
  • 公司法人往对公账户存钱
  • 个体户缴纳个人经营所得税分录
  • 怎么辨认专用发票真伪
  • 税务局代开专用发票要缴纳城建税吗?
  • 营改增后小规模ktv怎么纳税
  • 出售固定资产支付的相关费用计入
  • 企业银行密码器
  • 设计费计入成本
  • 工程预缴增值税2019最新规定
  • 租赁架子公司购车合法吗
  • 应交增值税为负数代表什么
  • 借贷记账法的记账规则是
  • .net 安装
  • win10系统中怎么共享文件
  • 累进税率的特点是课税对象的数额越大,税率越
  • 苹果手机怎么修改默认输入法
  • 小规模公司注销流程及费用
  • UPUPW 更新 64 位 Apache 系列 PHP 7.0 正式版
  • 跟踪路由如何实现
  • 贷款损失会计处理
  • 在承租的土地上建房
  • hipsdaemon.exe是什么
  • phpfopen
  • thinkphp yii
  • 超过认证期的发票怎么办
  • 一般纳税人未取得增值税专用发票怎么处理
  • 一年的云信承兑汇票如何提现
  • 程序员神器
  • php递归函数桃子一天吃一半
  • wordpress文章发布不显示作者
  • 税率变了
  • mongodb 日志
  • 个人注册公司是否可以免税
  • 现金流量表年报本期金额和上期金额
  • 可供出售交易性金融资产申报表怎么填
  • 通信服务费账务处理流程
  • 企业增值税征收范围
  • 火车退票费如何开票
  • 增值税减免税款计入什么科目
  • 小微企业免税的标准
  • 董事会会议的召集程序
  • 怎么结转本月期间损益
  • 福利补贴制度
  • mysql 5.7.28安装
  • creative cloud怎么用
  • U盘写保护怎么处理
  • 在win8下能直接装win7吗
  • linux播放mp3命令
  • CentOS 6.x 到 CentOS 7 的升级过程
  • win7主要有哪些内容
  • jquery实现select选择框内容左右移动代码分享
  • node.js开发指南
  • linux curl用法
  • xcopy命令拷贝目录
  • 用jquery制作网页
  • jquery右击事件
  • android 安卓开发 openssl
  • 土地增值税税率表
  • 如何计算增值税税负率公式
  • 什么叫关联单位
  • 如何落实请示汇报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设