sql 按时间段统计数据个数

本文介绍了SQL的基本插入和查询操作,包括插入数据到`using_time`表及根据时间范围查询数据的方法。示例涵盖了按天、昨天、一周内和30天内的数据统计,同时讲解了如`to_days`、`curdate()`等关键函数的用法。通过这些例子,读者可以更好地理解和运用SQL进行数据查询。
摘要由CSDN通过智能技术生成

插入数据sql样例

insert into `using_time` (`create_time`, `fid`) VALUES ("2022-09-15 14:24:50","17988413a036e3c80dd97d476f9d5b2f627a2cb20d8bcaa0af7f6a94cc8f1a6a");

在这里插入图片描述
查询sql样例

select count(*) from using_time where create_time between '2022-09-15 00:00:00' and '2022-09-15 23:59:59' ORDER BY create_time;
select count(*) from using_time where create_time between '2022-09-15' and '2022-09-16' ORDER BY create_time;

查询当天数据量

select count(*) from using_time where to_days(`create_time`) = to_days(now());
select count(*) from using_time where to_days(date_format(from_UNIXTIME(`create_time`),'%Y-%m-%d')) = to_days(now());
select count(*) from using_time where create_time >= DATE_ADD(NOW(),INTERVAL -0 day);

昨天

select count(*) from using_time where to_days(now()) = 1 + to_days(`create_time`);

一周内

select count(*) from using_time where date_sub(curdate(), INTERVAL 7 DAY) <= date(`create_time`);
select count(*) from using_time where create_time >= DATE_ADD(NOW(),INTERVAL -7 day);

30天

select count(*) from using_time where date_sub(curdate(), INTERVAL 30 DAY) <= date(`create_time`);

本月

select count(*) from using_time where date_format(`create_time`, '%Y%m') = date_format(curdate() , '%Y%m');

上个月

select count(*) from using_time where period_diff(date_format(now() , '%Y%m') , date_format(`create_time`, '%Y%m')) =1;

变量以及函数说明:

  • create_time为插入的时间
  • to_days是sql函数,返回的是个天
  • data()函数返回日期或日期/时间表达式的日期部分
  • curdate()函数返回当前的日期 y-m-d
  • data_format 用于以不同的格式显示日期/时间数据
  • period_diff(p1,p2)返回周期P1和P2之间的月数。 P1和P2格式为YYMM或YYYYMM。注意周期参数 P1 和 P2 都不是日期值
  • data_sub(date,INTERVAL expr type)给指定的日期减去多少天
  • data_add(date,INTERVAL expr type)给指定的日期加上多少天
  •   date_add(now(), interval 1 day); - 加1天
    
  •  date_add(now(), interval 1 hour); -加1小时
    
  •  date_add(now(), interval 1 minute); - 加1分钟
    
  •  date_add(now(), interval 1 second); -加1秒
    
  •  date_add(now(), interval 1 microsecond);-加1毫秒
    
  •  date_add(now(), interval 1 week);-加1周
    
  •  date_add(now(), interval 1 month);-加1月
    
  •  date_add(now(), interval 1 quarter);-加1季
    
  •  date_add(now(), interval 1 year);-加1年
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值