位置: 编程技术 - 正文

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)

  • 税收减免的定义
  • 价外税和价内税的理解
  • 所得税五个年度纳税弥补是如何算的?
  • 提现的手续费怎么做账
  • 财产租赁合同印花税计税依据含税吗
  • 免 抵 退
  • 公司在筹备阶段可以不交社保
  • 软件 折旧年限
  • 会计软件每年都要付钱的吗
  • etc充值怎么操作
  • 所有者投入的资本属于什么科目
  • 免税进口的自用设备再销售时该怎么征税
  • 资本公积金转增股本是利好吗
  • 什么情况下可以报警
  • 赠送客户的商品怎么入账
  • 销售研发试制样板图
  • 行政单位暂付款怎么记账
  • 企业进货不收发票怎么做帐?
  • 企业员工应付未付的工资该如何写其会计分录?
  • 发票的受票方是什么
  • 个税零申报工资填0吗
  • 计提所得税费用会计分录
  • 市政工程税率多少
  • 递延所得税资产借贷方向
  • 对外投资收益要交税吗
  • 生产废料怎么处理会计分录
  • 融资租赁的租金是什么意思
  • 待机最长的手机智能排行榜 2020
  • 预防cpu被烧毁的办法
  • 百度地图api的基本使用
  • PHP:parse_ini_string()的用法_Filesystem函数
  • 子公司使用母公司授信
  • vue调整图标大小
  • 搬迁收入增值税
  • 工具人
  • 工程实践指的是
  • 做毕业设计,前景如何
  • php实现当前页面的快捷键
  • 2022年最新公务接待用餐标准
  • 哪些公司不交五险一金
  • open com failed
  • 收到的普票金额多开了怎么处理呢
  • 两处取得收入,如何进行个税的申报?
  • 可以抵扣增值税进项税额的有哪些
  • MySQL中distinct语句的基本原理及其与group by的比较
  • MySQL: mysql is not running but lock exists 的解决方法
  • mysql金额用什么数据类型
  • 股东收到投资收益会计科目
  • 结账与对账的共同意义在于
  • 房地产采取按揭销售的,其销售的入账时间为
  • 预付款项怎么做分录
  • 已认证的增值税专用发票退票
  • 在租赁的土地上建房做固定资产吗
  • 投资性房地产与持有待售资产的区别
  • 闲置资产计提折旧
  • 结转增值税的账务处理一定要通过转出未交增值税吗
  • 科技经费使用
  • 什么是限售股融券
  • 持有至到期投资改名为
  • 用于职工福利的增值税怎么计算
  • 主键自增长的数据如何导入
  • mysql修改默认编码
  • 快速释放剪贴蒙版快捷键
  • 在microsoft store
  • macbookairfacetime
  • linux extundelete
  • linux的awk命令大全
  • linux乱码怎么办
  • win8系统关机键找不见
  • linux计划任务如何设置
  • linux删除sdb1
  • win7系统怎么锁定屏幕
  • win8双系统怎么删除一个
  • unity做app开发
  • android 实例
  • bat延迟1秒
  • javascript playground
  • android反编译smali
  • 辽宁地方税务局发票查询
  • 青岛电子税务局电话人工客服电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设