未加星标

Mysql根据时间查询日期的优化技巧

字体大小 | |
[数据库(mysql) 所属分类 数据库(mysql) | 发布者 店小二03 | 时间 | 作者 红领巾 ] 0人收藏点击收藏

例如查询昨日新注册用户,写法有如下两种:

EXPLAIN
select * from chess_user u where DATE_FORMAT(u.register_time,'%Y-%m-%d')='2018-01-25';
EXPLAIN
select * from chess_user u where u.register_time BETWEEN '2018-01-25 00:00:00' and '2018-01-25 23:59:59';

register_time字段是datetime类型,转换为日期再匹配,需要查询出所有行进行过滤。而第二种写法,可以利用在register_time字段上建立索引,查询极快!

Mysql根据时间查询日期的优化技巧
Mysql根据时间查询日期的优化技巧

附上日期转换函数

DECLARE yt varchar(10); #昨天
DECLARE yt_bt varchar(19); #昨天开始时间
DECLARE yt_et varchar(19); #昨天结束时间
#设置变量
SET yt=DATE_FORMAT(DATE_ADD(now(),INTERVAL -1 day),'%Y-%m-%d');
SET yt_bt=DATE_FORMAT(DATE_ADD(now(),INTERVAL -1 day),'%Y-%m-%d 00:00:00');
SET yt_et=DATE_FORMAT(DATE_ADD(now(),INTERVAL -1 day),'%Y-%m-%d 23:59:59');

总结

以上所述是小编给大家介绍的mysql根据时间查询日期的优化技巧,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!


您可能感兴趣的文章:mysql 获取昨天日期、今天日期、明天日期以及前一个小时和后一个小时的时间解析MySQL中存储时间日期类型的选择问题JDBC中使用Java8的日期LocalDate和LocalDateTime操作mysql、postgresqlMySQL 获得当前日期时间 函数浅谈MySQL数据库中日期中包含零值的问题MySQL查询两个日期之间记录的方法详解MySQL日期 字符串 时间戳互转详解mysql 获取当前日期及格式化mysql中格式化日期详解mysql如何查询两个日期之间最大的连续登录天数mysql日期date型和int型互换的方法mysql记录根据日期字段倒序输出mysql常用日期时间/数值函数详解(必看)MySql判断汉字、日期、数字的具体函数MySQL中日期和时间戳互相转换的函数和方法Mysql获取当前日期的前几天日期的方法mysql 获取当前日期函数及时间格式化参数详解MySQL日期函数与日期转换格式化函数大全

本文数据库(mysql)相关术语:navicat for mysql mysql workbench mysql数据库 mysql 存储过程 mysql安装图解 mysql教程 mysql 管理工具

主题: MySQLSQLJava谢大数据变量数据库
tags: 日期,mysql,DATE,MySQL,yt,函数,查询,register,FORMAT,time,详解,时间
分页:12
转载请注明
本文标题:Mysql根据时间查询日期的优化技巧
本站链接:http://www.codesec.net/view/573494.html
分享请点击:


1.凡CodeSecTeam转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
登录后可拥有收藏文章、关注作者等权限...
技术大类 技术大类 | 数据库(mysql) | 评论(0) | 阅读(65)