位置: 编程技术 - 正文

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)

  • 消费税是指什么税
  • 劳务报酬所得税可以退税吗
  • 如何查询企业税务状态
  • 什么是税务登记管理
  • 职工个人所得税
  • 以前多摊销
  • 结转固定资产清理的会计科目
  • 应收利息增加会计分录
  • 小微企业一般要交什么费用2019
  • 如何查询对方是不是一般纳税人
  • 公允价值变动损益属于什么科目
  • 取得出口退税款算什么收入
  • 小规模纳税人开票税率
  • 进项税额转出后企业所得税怎么处理?
  • 企业在筹建期间发生的费用
  • 总资产周转率多少算高
  • 库存商品怎么结转损益
  • 收到财产保险赔款会计分录
  • 资产负债表没有实收资本正常吗
  • 清算资金往来借贷方什么意思
  • 农业公司的会计分录
  • 公司购消防器材会计分录
  • thinkphp5控制器
  • 防水工程质量问题
  • 代扣代缴个税手续费
  • 其他综合收益和其他收益的区别
  • 收到完税凭证怎么做账
  • 进项发票失控怎么办
  • 报销费用多付会计分录
  • 网络看不到局域网图标
  • hbuilderx怎么运行代码
  • 海关专用缴款书认证的步骤和说明
  • 一个实用的php验证
  • 信托融资放在哪个科目
  • 自然人税收管理系统扣缴客户端app
  • 解决前端跨域问题
  • php curl_exec
  • java前后端加密解密请求
  • autocut跟踪调节
  • 建筑业成本核算流程
  • 计提本月房产税的纳税基数怎么算的
  • 公司交社保国家承担吗
  • 处置结余的工程款怎么算
  • 企业账户对私人账户转账多久到账
  • 生产辅助
  • 企业转让股权如何缴纳企业所得税
  • 个税系统经营所得人员怎样添加
  • 个人所得税专项扣除2023最新政策
  • mysql数据库操作中,use是用来做什么的?
  • 企业非流动资产包括
  • 融资租入固定资产的入账价值
  • 资产基金账务处理
  • 退货只能退一半价钱合理吗
  • 在保险中,保险利益的载体是
  • 技术服务类有哪些
  • 什么是资产减值准备计提
  • 未缴纳或未足额缴纳出资的股东
  • 备查账依据什么登记
  • sqlserver用户权限不给增删查改表结构权限
  • MSSQL 数据库同步教程
  • Linux安装MySQL教程(二进制分发版)
  • 繁体系统安装简体软件
  • centosuuid
  • win8分盘怎么分
  • windowsxp有密码忘了怎么办
  • win7如何开机修复系统
  • win7可以免费升win10
  • 更换主板也不用换硅脂吗
  • ipcservice.dll是什么?
  • win10一年更新几次
  • 怎么对js代码程序进行设计
  • [置顶] [寒江孤叶丶的Cocos2d-x之旅_29]在Cocos2d-x中集成protobuf (Protocol Buffers)
  • shell随机
  • android studio环境
  • shell脚本中执行命令语句
  • jquery全选和全不选效果
  • 专项附加扣除当月填报何时生效
  • 江苏省定额规则
  • 安徽增值税普通发票税率1%
  • 上海增值税发票红字怎么开
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设