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') < DATE_FORMAT('1990-03-07','%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);

 

转载于:https://my.oschina.net/u/782865/blog/668482

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值