DB2或MySql的week_iso或weekOfYear()与java的Calendar.WEEK_OF_YEAR保持一致

package cn.bevis.time;


import java.text.SimpleDateFormat;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Date;


public class TimeUtil {


/**
* JAVA的Calendar.WEEK_OF_YEAR与DB2或MySql数据库中week_iso(date)或weekOfYear(date),结果保持一致的方法
* 这样做统计的时候免去很多麻烦,无意中发现的,分享给大家!!!!!!
* 如果有高手,可以帮我解释一下,本人目前还不太清楚!!!,谢谢!
* @param date
* @return
*/

public static int[] getWeekOfYear(Date date) {  
       Calendar calendar = Calendar.getInstance();  
       //设置周一为一周的第一天
       calendar.setFirstDayOfWeek(Calendar.MONDAY); 
        //这样可以与数据库中weekOfYear保持一致
       //Mysql-->weekOfYear(date)//周一为一周的第一天
       //DB2-->week_iso(date)//周一为一周的第一天

       calendar.setMinimalDaysInFirstWeek(4); //这里设置为4-->原因不详!
       calendar.setTime(date);  
       int week = calendar.get(Calendar.WEEK_OF_YEAR);  

       int year = calendar.get(Calendar.YEAR);


      //如果周次落在最后一周,那么日历向前翻一个月,再去取年份,避免最后一周年份获取有误
      if(weekNum == 52 || weekNum == 53 || weekNum == 54){
          calendar.add(Calendar.MONTH, -1);
          year = calendar.get(Calendar.YEAR);
       }

       return new int[]{year,week};  
   }  
 
public static void main(String[] args) {

   for (int i = 0; i < 8; i++) {
      Calendar cal = Calendar.getInstance();
      cal.set(2015, 11, 28);
      cal.add(Calendar.DAY_OF_YEAR, i);

      String dateStr = new SimpleDateFormat("yyyy-MM-dd").format(cal.getTime());
      System.out.println(dateStr); //打印当前日期-->2015-12-28

      int[] result = getWeekOfYear(cal.getTime());

      System.out.println(Arrays.toString(result)); //打印年份与周次-->[2015, 53]:表示2015年第53周

    }
  }
}


//--------打 印 结 果------->
//2015-12-28
//[2015, 53]
//2015-12-29
//[2015, 53]
//2015-12-30
//[2015, 53]
//2015-12-31
//[2015, 53]
//2016-01-01
//[2015, 53]
//2016-01-02
//[2015, 53]
//2016-01-03
//[2015, 53]
//2016-01-04

//[2016, 1]

//MySql的结果

SELECT WEEKOFYEAR('2015-12-28') as a FROM DUAL-->53
UNION ALL
SELECT WEEKOFYEAR('2015-12-29') as a FROM DUAL-->53
UNION ALL
SELECT WEEKOFYEAR('2015-12-30') as a FROM DUAL-->53
UNION ALL
SELECT WEEKOFYEAR('2015-12-31') as a FROM DUAL-->53
UNION ALL
SELECT WEEKOFYEAR('2016-01-01') as a FROM DUAL-->53
UNION ALL
SELECT WEEKOFYEAR('2016-01-02') as a FROM DUAL-->53
UNION ALL
SELECT WEEKOFYEAR('2016-01-03') as a FROM DUAL-->53
UNION ALL
SELECT WEEKOFYEAR('2016-01-04') as a FROM DUAL-->1


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值