请看看吧,如何让功能实现

date类以String存储在数据库mysql,以类Note封装记录,获取mysql中的String类型之后,如何强制转换,实现日期类相减,得到一个int类型的返回值

 

public  int jiaofei111(Note a) throws Exception{ //判断是否交费及钱数
            
             

              SimpleDateFormat  sdf=new SimpleDateFormat("yyyy-MM-dd");
              Date d1=(Date) sdf.parse(a.getReturntime());//结束时间  //强制转换string->date
              Date d2=(Date) sdf.parse(a.getLenttime());//结束时间  //强制转换string->date
                     int stateTimeLong = (int) d1.getTime();
                    int endTimeLong =(int) d2.getTime();
                    // 结束时间-开始时间 = 天数
                    int day = (int)(endTimeLong-stateTimeLong)/(24*60*60*1000); 
                    if(day>30) return day;                
                    else{day=0;}        

                    return day;
              
        }
 

给你个工具类

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


public class test1 {

    /**
     * @param args
     * @throws ParseException 
     */
    public static void main(String[] args) throws ParseException {
        // TODO Auto-generated method stub
        SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        Date d1=sdf.parse("2012-09-08 10:10:10");
        Date d2=sdf.parse("2012-09-15 00:00:00");
        System.out.println(daysBetween(d1,d2));

        System.out.println(daysBetween("2012-09-08 10:10:10","2012-09-15 00:00:00"));
    }
    
    /** 
     * 计算两个日期之间相差的天数 
     * @param smdate 较小的时间
     * @param bdate  较大的时间
     * @return 相差天数
     * @throws ParseException 
     */  
    public static int daysBetween(Date smdate,Date bdate) throws ParseException  
    {  
        SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");
        smdate=sdf.parse(sdf.format(smdate));
        bdate=sdf.parse(sdf.format(bdate));
        Calendar cal = Calendar.getInstance();  
        cal.setTime(smdate);  
        long time1 = cal.getTimeInMillis();               
        cal.setTime(bdate);  
        long time2 = cal.getTimeInMillis();       
        long between_days=(time2-time1)/(1000*3600*24);
          
       return Integer.parseInt(String.valueOf(between_days));         
    }  
    
  /**
   *字符串的日期格式的计算
   */
    public static int daysBetween(String smdate,String bdate) throws ParseException{
        SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");
        Calendar cal = Calendar.getInstance();  
        cal.setTime(sdf.parse(smdate));  
        long time1 = cal.getTimeInMillis();               
        cal.setTime(sdf.parse(bdate));  
        long time2 = cal.getTimeInMillis();       
        long between_days=(time2-time1)/(1000*3600*24);
          
       return Integer.parseInt(String.valueOf(between_days));   
    }

}