位置: 编程技术 - 正文

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)

  • 弥补亏损的应纳税额 例子
  • 应交增值税是什么意思
  • 船舶吨税范围
  • 幼儿园财务科目设置
  • 减免所得税优惠明细表怎么填
  • 普通折叠发票代码是几位数
  • 酒店出租会议室增值税税率
  • 如何根据会计凭证登记账簿
  • 企业股权转让是否交企业所得税
  • 房地产契税新政策2021退税
  • 前年度库存商品少结转业务怎么处理?
  • 管理部门购入固定资产
  • 增值税进项税已转出后能否再抵扣
  • 企业破产应收账款要发询证函吗
  • 加工费可以计入管理费用吗
  • windows10如何卸载edge
  • 永恒之蓝是
  • 水利基金减免怎么做账
  • w10怎么找蓝牙
  • 上一年度的费用入账需要分摊吗
  • 蝾螈白话怎么读
  • PHP:mb_output_handler()的用法_mbstring函数
  • Linux系统怎么配置IP
  • P2PNetworking3.exe - P2PNetworking3是什么进程 有什么用
  • ctfmon.exe文件在哪
  • 未确认融资收益怎么理解
  • 财务收支审批制度主要包括
  • 记账凭证和原始凭证都是登记账簿的直接依据
  • 来料加工企业需注意什么
  • 工伤报销入账
  • php 跨域
  • 个体经营所得税申报表a
  • GPT-4 手画设计稿 直接生成前端页面
  • 计提票面利息
  • 社保缴费基数3400
  • 出租房屋房产税计算
  • 外贸退税是算利率吗
  • sql server 2008r
  • mongodb主备配置
  • 交易性金融资产属于什么科目
  • 财务费用利息收入是什么意思
  • 个税申报赡养老人可以填公婆吗
  • 受托方代扣代缴增值税、消费税的纳税人
  • 公司开发新产品时,由管理层任命的
  • 主要业务活动是什么意思
  • 企业收取的丢失物品
  • 职工薪酬纳税调整
  • 工程款多付了如何追回
  • 印花税如何计算缴纳
  • 收到法院退回的诉讼费怎么做账
  • 待摊费用年底能够有余额么
  • 结算本月应付职工工资,其中生产工人工资8000元
  • 测绘费如何入账
  • 确认收入一定要交增值税吗
  • 工程公司本月没发工资
  • 结算金额和付款金额
  • 买钢管扣件
  • 班车租赁费计入福利费吗
  • sql server临时表创建语句
  • ubuntu浏览网页
  • centos6.10安装教程详解
  • 如何在安装未知应用中修改权限
  • 苹果电脑支持的u盘格式
  • centos新建终端快捷键
  • win10系统出现问题怎么办
  • win7命令提示符怎么以管理员身份运行
  • win8系统安装条件
  • 滤镜调试
  • css盒子模型示意图
  • python到底怎么学
  • python读取文件指定内容
  • mac的命令
  • linux如何查看当前shell
  • webgl fbo
  • winpe文件下载
  • 吉林省税务局发票查询真伪
  • 常州国家税务局待遇
  • 税务系统领发票
  • 如何在个税app中设置企业登录密码
  • 海宁到许村公交车路线
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设