mysql 按日期统计_mysql 按日期统计数据

--按年查询

select * from salaries where year(to_date) = year('1988-05-06')

--按年/月查询,

select * from salaries where month(to_date) = month('1988-03-02') and year(to_date) = year('1988-03-02')

--按日查询

select * from salaries where day(to_date) = day('1988-03-02')

--按天统计

select DATE_FORMAT(to_date, '%Y-%m-%d') days

from salaries

where DATE_FORMAT(to_date, '%Y-%m-%d') in ('1988-03-01','1988-03-11','1988-03-20')

group by days;

--按月统计

select DATE_FORMAT(to_date, '%Y-%m') months

from salaries

where DATE_FORMAT(to_date, '%Y-%m') in ('1988-03','1988-04','1988-05','1988-06','1988-07')

group by months;

--按周统计(跨年的周会统计出两条数据)

select DATE_FORMAT(to_date, '%Y%u') weeks, to_date

from salaries

where DATE_FORMAT(to_date, '%Y%u') > DATE_FORMAT('1988-03-01', '%Y%u') and DATE_FORMAT(to_date, '%Y%u') 

group by weeks

select DATE_FORMAT(to_date, '%Y%m%d') days, emp_no, sum(salary), from_date, to_date from salaries group by days;

--按周统计

%V 周 (01-53) 星期日是一周的第一天,与 %X 使用

%v 周 (01-53) 星期一是一周的第一天,与 %x 使用

java代码根据年的第几周获取是月的第几周

Calendar calendar = Calendar.getInstance();

//年,第几周,星期几(从星期天开始1)

calendar.setWeekDate(1988,10,6);

String strDate = DateFormat.getDateTimeInstance().format(calendar.getTime());

System.out.println("时间是:"+strDate);

int weekOfMonth = calendar.get(Calendar.WEEK_OF_MONTH);

System.out.println("一年中的第几个星期:"+calendar.get(Calendar.WEEK_OF_YEAR));

System.out.println("该月的第几个星期:"+weekOfMonth);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值