位置: 编程技术 - 正文

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)

  • 运费收入算销售收入吗
  • 电子发票入账是什么意思
  • 电子税务局申报的财务报表在哪里查询
  • 投资性房地产递延所得税资产怎么算
  • 公司废品处理一定要入账吗
  • 代缴水电费如何做账
  • 所得税申报表中的资产总额如何填
  • 民营企业的待遇
  • 厂家试驾车和经销商试驾车
  • 手工帐怎么登记
  • 固定资产超过注册资金怎么处理
  • 会计中预付款包括
  • 公司购入货架如何做账
  • 银行里的钱没有了怎么办
  • 小苏打税收分类
  • 专用发票地址写错字了能用吗
  • 员工看病报销要计税吗
  • 土地使用权摊销账务处理
  • 建筑公司收到的劳务费怎么做账
  • 企业为开发新产品新技术新工艺
  • 研发阶段产品销售账务处理
  • php快递查询系统
  • RegSrvc.exe - RegSrvc是什么进程 有什么用
  • 认缴出资没到位违法吗
  • 其他应付款的核算范围包括应付短期租赁
  • win7系统文件在哪里可以找到
  • 外国人在中国工作有五险一金吗
  • 微前端架构实现
  • framework4.0怎么打开
  • php对数组进行排序
  • python雪花算法生成id
  • es工具类
  • gpt3 transformer
  • 海关缴款书稽核比对
  • 多缴所得税怎么算
  • 差旅费的处理
  • 企业应纳税总额怎么算
  • 公司注销了,账务是不是可以销毁了
  • 出口货物关税完税价格包括哪些
  • 茶叶企业所得税减免
  • 纳税申报人的对象是哪些
  • mysql官方性能报告
  • 个体户需要实缴吗
  • 个人独资企业一般纳税人享受六税两费
  • 年度亏损计提所得税吗
  • 什么是商业汇票,其种类有哪些
  • 公司房租发票是法人名字能入账吗安全吗
  • 按揭房办理抵押贷款
  • 车辆处置收入怎么交税
  • 事业单位如何调档案
  • 合同负债属于什么账户
  • 直接计入管理费用的税金有哪些
  • 汇兑损益的账务处
  • 非公司员工可以发提成吗
  • 其他应付款的借贷方分别表示什么
  • 发票开多了如何做凭证?
  • 完成认证后开具什么证明
  • 公司基本户可以取现金吗
  • 滴滴出行怎么开纸质发票
  • 电脑svchost占用cpu很大
  • ubuntu一键重装
  • 进程是什么 进程类型
  • mac系统如何隐藏文件
  • centos minio
  • zmweb.exe是什么进程
  • win7安全模式
  • android mark
  • linux shell脚本命令
  • 电脑自动重启命令
  • Node.js中的全局对象有
  • js过滤特殊字符
  • js div拖动
  • unity shader 外发光
  • 税务稽查案件办案程序规定
  • 珠宝消费税怎么计算出来的
  • 灵活就业登记审核查询
  • 沭阳税务局举报电话
  • 税务ukey登录界面
  • 北京社保登记证怎么办
  • 浙江税务局网络发票页无法打字
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设