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代码根据年的第几周获取是月的第几周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);
相关文章
相关标签/搜索