位置: 编程技术 - 正文

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)

  • 企业所得税汇算清缴
  • 一般纳税人纳税申报时间
  • 出租房屋取得的收入计入什么
  • 会计一般什么时候考试
  • 由商场代收营业费怎么算
  • 建立明细账的注意事项
  • 研发支出的材料费
  • 财产租赁合同印花税优惠政策
  • 暂估入库发票差额怎么办
  • 资产负债表的资产方能够提供的信息包括
  • 找贴现公司贴现有风险吗
  • 开发成本可以计增值税吗
  • 应交税金属于什么会计分录
  • 项目上发生伙食问题
  • 分公司和总公司的财务是分开的吗
  • 车辆保险可以开票吗
  • 个人机械租赁费税率
  • 公司主要业务介绍
  • 母公司给子公司担保
  • 嵌入式软件开发工程师
  • 辞退员工会计分录
  • 没有及时对公账户
  • 工商营业年报怎么做
  • 1697508019
  • 增值税差旅费可以扣除吗
  • 公司增资怎么做
  • 公司不经营了不注销可以吗
  • php生成二维码源码
  • 研发费用加计扣除政策指引2.0
  • 滞纳金不得超过税款
  • frameworkscheduled
  • 员工每月补助表怎么做
  • 矿产资源补偿费与采矿权价款区别
  • json与json字符串
  • php similar_text()函数的定义和用法
  • h5支付功能
  • js位运算有什么用
  • 【GitHub Copilot X】基于GPT-4的全新智能编程助手
  • 小规模纳税人季度不超30万怎么做账
  • 行政事业单位支出劳务费规定
  • 企业所得税如何征收
  • 帝国cms移动端设置教程
  • 移动怎么开当月发票
  • 合伙企业对外投资需要全体合伙人同意吗
  • 固定资产一次性加速折旧
  • 公司聘请专家工资怎么算
  • 劳务派遣公司小规模纳税人如何开票
  • 在建工程转固定资产是什么意思?
  • 外借资质交企业所得税怎么交
  • 信用证保证金的适用范围
  • 境外企业分红到境内
  • 现金不够老板垫钱怎么办
  • 小规模开票免税额度是多少
  • 认缴款和投资款区别
  • 劳务派遣中谁给劳动者发工资
  • 坏账准备怎么计提比例
  • sqlserver中时间类型
  • MySQL关键字执行顺序
  • MySQL去除重复数据
  • 在windows操作中
  • win2003系统要求
  • macOS 10.12.2下PDF崩溃严重怎么回事 macOS 10.12.2下PDF崩溃的原因以及解决办法
  • macos 右键菜单
  • centos设置服务自启动
  • win8点击桌面没反应
  • 电脑win7在哪
  • win7系统硬盘
  • win8开机直接进入传统桌面
  • php获取当前脚本路径
  • jquery form序列化
  • shell中for循环如何用sed
  • unity 2021.2
  • python和微信交互
  • 核定征收怎么计算税额
  • 税务非正常户要提交什么资料
  • 增值税防伪税控开票实训心得
  • 广东税务微信公众号微办税
  • 新郑市税务局
  • 社会保险登记表下载
  • 2020十大经济年度人物揭晓
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设