建表语句:

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------

-- Table structure for t_user

-- ----------------------------

DROP TABLE IF EXISTS `t_user`;

CREATE TABLE `t_user` (

`userId` bigint(20) NOT NULL,

`fullName` varchar(64) NOT NULL,

`userType` varchar(16) NOT NULL,

`addedTime` datetime NOT NULL,

PRIMARY KEY (`userId`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of t_user

-- ----------------------------

INSERT INTO `t_user` VALUES ('1', '爽爽', '普通', '2018-01-21 10:20:09');

INSERT INTO `t_user` VALUES ('2', '贵贵', '普通', '2017-11-06 10:20:22');

INSERT INTO `t_user` VALUES ('3', '芬芬', 'vip', '2017-11-13 10:20:42');

INSERT INTO `t_user` VALUES ('4', '思思', 'vip', '2018-01-21 10:20:55');

INSERT INTO `t_user` VALUES ('5', '妍妍', 'vip', '2017-09-17 10:21:28');

时间段查询语句:

-- 今天

select fullName,addedTime from t_user where to_days(addedTime) <= to_days(now());

-- 昨天

select fullName,addedTime from t_user where to_days(NOW()) - TO_DAYS(addedTime) <= 1;

-- 近7天

select fullName,addedTime from t_user where date_sub(CURDATE(),INTERVAL 7 DAY) <= DATE(addedTime);

-- 近30天

SELECT fullName,addedTime FROM t_user where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(addedTime);

-- 本月

SELECT fullName,addedTime FROM t_user WHERE DATE_FORMAT( addedTime, '%Y%m' ) = DATE_FORMAT( CURDATE() , '%Y%m' );

-- 上一月

SELECT fullName,addedTime FROM t_user WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( addedTime, '%Y%m' ) ) =1;

-- 查询本季度数据

select fullName,addedTime FROM t_user where QUARTER(addedTime)=QUARTER(now());

-- 查询上季度数据

select fullName,addedTime FROM t_user where QUARTER(addedTime)=QUARTER(DATE_SUB(now(),interval 1 QUARTER));

-- 查询本年数据

select fullName,addedTime FROM t_user where YEAR(addedTime)=YEAR(NOW());

-- 查询上年数据

select fullName,addedTime FROM t_user where year(addedTime)=year(date_sub(now(),interval 1 year));

-- 查询距离当前现在6个月的数据

select fullName,addedTime FROM t_user where addedTime between date_sub(now(),interval 6 month) and now();

-- 查询当前这周的数据

SELECT fullName,addedTime FROM t_user WHERE YEARWEEK(date_format(addedTime,'%Y-%m-%d')) = YEARWEEK(now());

-- 查询上周的数据

SELECT fullName,addedTime FROM t_user WHERE YEARWEEK(date_format(addedTime,'%Y-%m-%d')) = YEARWEEK(now())-1;

-- 查询上个月的数据

select fullName,addedTime FROM t_user where date_format(addedTime,'%Y-%m')=date_format(DATE_SUB(curdate(), INTERVAL 1 MONTH),'%Y-%m');

-- 查询当前月份的数据

select fullName,addedTime FROM t_user where DATE_FORMAT(addedTime,'%Y%m') = DATE_FORMAT(CURDATE(),'%Y%m');

select fullName,addedTime FROM t_user where date_format(addedTime,'%Y-%m')=date_format(now(),'%Y-%m');

-- 查询指定时间段的数据

select fullName,addedTime FROM t_user where addedTime between '2017-1-1 00:00:00' and '2018-1-1 00:00:00';

select fullName,addedTime FROM t_user where addedTime >='2017-1-1 00:00:00' and addedTime < '2018-1-1 00:00:00';

归纳:

1、查询时间段内的数据,一般可以用between and 或 <> 来指定时间段。

2、mysql的时间字段类型有:datetime,timestamp,date,time,year。

3、 获取系统当前时间的函数:

select CURDATE();

select NOW();

4、获取时间差的函数:

period_diff() datediff(date1,date2) timediff(time1,time2)

5、日期加减函数:

date_sub()

date_add() adddate() addtime()

period_add(P,N)

6、时间格式转化函数:

date_format(date, format) ,MySQL日期格式化函数date_format()

unix_timestamp()

str_to_date(str, format)

from_unixtime(unix_timestamp, format) ,MySQL时间戳格式化函数from_unixtime

mysql查询特定时间段内的数据_mysql查询特定时间段内的数据相关推荐

  1. mysql查询表里面重复的数据_mysql查询表里的重复数据方法

    这篇文章主要介绍了mysql查询表里的重复数据方法,需要的朋友可以参考下 INSERT INTO hk_test(username, passwd) VALUES ('qmf1', 'qmf1'),( ...

  2. mysql查询没有被关联的数据_Mysql - 查询之关联查询

    查询这块是重中之重, 关系到系统反应时间. 项目做到后期, 都是要做性能测试和性能优化的, 优化的时候, 数据库这块是一个大头. sql格式: select 列名/* from 表名 where 条件 ...

  3. mysql查询按值多的排序_MySQL查询结果按某值排序

    MySQL查询结果按某值排序 使用MySQL很多时候我们不仅只是查询出结果,还需要对查询结构进行排序,下文对查询结果按某值排序的方法作了详细的介绍,供您参考. AD: MySQL查询结果如何排序呢?这 ...

  4. mysql索引可以提高什么的操作效率_MySQL查询性能优化前,必须先掌握MySQL索引理论...

    数据库索引在平时的工作是必备的,怎么建索引,怎么使用索引,可以提高数据的查询效率.而且在面试过程,数据库的索引也是必问的知识点,比如:索引底层结构选型,那为什么选择B+树? 不同存储引擎的索引的体现形 ...

  5. mysql 处理数据_MySQL数据库,如何处理重复的数据?

    前言 这是一个基本问题,这篇文章是我很早之前遇到的一种情况,后来在学习视频的时候又遇到了一次,因此给出一个总结.其实解决能否插入重复数据的问题,一般情况下是有两个思路,就像治水一样,第一个就是从源头, ...

  6. mysql查询最新的一条记录_mysql 查询不同用户 最新的一条记录

    数据库记录: MYSQL查询不同用户 最新的一条记录 方法1:查询出结果后将时间排序后取第一条(只能取到一条,并且不能查询不同客户的记录) SELECT CUSTOMER_ID,CONTENT,MOD ...

  7. mssql 将查询结果作为表名参数_MySQL·查询(一)

    最近把时间都放在了回顾SQL语言上,因为能够按照需求在数据库中提取数据是非常重要的,太久没有去碰SQL,所以就花了一段时间去重新总结关于MySQL中的查询,希望下面简单的总结可以帮助大家理解SQL的查 ...

  8. mysql数据库获得时间段内数据_mysql 获取规定时间段内的统计数据

    mysql 获取规定时间段内的统计数据 按年统计SELECT count(*), DATE_FORMAT(order_info.create_time, '%Y-%m-%d') AS count_by ...

  9. mysql语句查询今天的数据_mysql查询当天所有数据sql语句

    mysql查询当天的所有信息: select * from test where year(regdate)=year(now()) and month(regdate)=month(now()) a ...

  10. mysql 查找数据_Mysql查询数据

    查询语句 单表查询 1.1 全表查寻 select * from employee; 复制代码1.2 指定字段查询 查询职员表中所有职员姓名和入职时间 select empname,hirdate f ...

最新文章

  1. python生成一个窗口_PyQt5创建一个新窗口的实例
  2. 中自苏研院2021招聘季开始啦!
  3. A Quick Guide For Windows 2008 Server Core
  4. 计算机与图像处理论文标题,数字图像处理论文各种题目.doc
  5. 【Paper】2020_Qize_Design of UGV Trajectory Tracking Controller in UGV-UAV Cooperation
  6. 使用计算机加密码,给正使用的电脑设置密码
  7. SQL Server 2012 中的 Service Broker功能的一些改进或增强
  8. 其实,这仅仅是个开始
  9. 【渝粤题库】陕西师范大学292391 金融机构管理 作业(专升本)
  10. 三次样条曲线拟合及Matlab/Python实现
  11. 一打开excel表,总提示有4.0版的宏
  12. spark数据查询语句select_Spark-SQL之DataFrame操作大全
  13. POJ1703-Find them, Catch them
  14. Firefox4开发计划公布:使浏览器得更快更强
  15. Python打造自动在线刷视频—一个只能做不能说的项目。
  16. vscode中文乱码
  17. 程序员应当正确突破英语障碍
  18. 单曲循环 翻译_“单曲循环” 用哪个词?
  19. 快手2020校园招聘秋招笔试--工程A试卷
  20. Maya常用快捷键(转)

热门文章

  1. javascript 逻辑运算符 和 或 非
  2. SQLite读写同步之WAL机制
  3. 域名可以用多久_一个域名能用多少年
  4. 档案管理系统,项目总结
  5. 5.17 图层面板的使用 [原创Ps教程]
  6. 如何看待网络直播中的弹幕文化?
  7. libvlc.java_java – LibVlc android无法加载库
  8. 【学习笔记】图像纹理特征
  9. 学会Python,再也不愁给孩子起名字了
  10. android文件浏览器,安卓最强大的文件浏览器:ES文件浏览器