Annette_wang 2021-06-26 07:41 采纳率: 84.6%
浏览 8
已结题

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

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;
              
        }
 

  • 写回答

1条回答 默认 最新

  • li.siyuan 2021-06-28 13:13
    关注

    给你个工具类

    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));   
        }
    
    }
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 12月22日
  • 已采纳回答 12月14日