sql >> Databasteknik >  >> RDS >> Oracle

Datumskillnad i datum i Oracle och Java

Datumet kan vara detsamma men tiden kan vara annorlunda. Resulterar i 139 dagar när du räknar genom millisekunder. (java)

Jag föreslår att du inte använder millis utan använder dagarna för att beräkna.

Något liknande

public long daysBetween(Calendar startDate, Calendar endDate) {
   Calendar date = (Calendar) startDate.clone();
   long daysBetween = 0;
   while (date.before(endDate)) {
      date.add(Calendar.DAY_OF_MONTH, 1);
      daysBetween++;
   }}

eller

/**
     *
     * @param c1 from
     * @param c2 to
     * @return amount of days between from and to
     */
    public int diff(Calendar c1, Calendar c2) {
        int years = c2.get(Calendar.YEAR) - c1.get(Calendar.YEAR);
        if (years == 0) {
            return c2.get(Calendar.DAY_OF_YEAR) - c1.get(Calendar.DAY_OF_YEAR);
        } else {
            Calendar endOfYear =  Calendar.getInstance();
            endOfYear.set(Calendar.YEAR, c1.get(Calendar.YEAR));
            endOfYear.set(Calendar.MONTH, 11);
            endOfYear.set(Calendar.DAY_OF_MONTH, 31);
            int days = endOfYear.get(Calendar.DAY_OF_YEAR) - c1.get(Calendar.DAY_OF_YEAR);
            for (int i=1;i <years;i++) {
                endOfYear.add(Calendar.YEAR, 1);
                days += endOfYear.get(Calendar.DAY_OF_YEAR);
            }
            days += c2.get(Calendar.DAY_OF_YEAR);
            return days;
        }
    }

Sidanteckning:Det första exemplet är något långsammare än det andra, men om det bara är för små skillnader är det försumbart.



  1. Alternativ till RETURNERING med INSERT...SELECT

  2. MySQL-rapporteringstjänster med öppen källkod

  3. MySQL främmande nycklar på mig själv

  4. Android - Hur kan jag skicka data relaterade till två tabeller till en insättningsmetod hos en innehållsleverantör