sql >> Databáze >  >> RDS >> Oracle

Rozdíl dat v datech v Oracle a Java

Datum může být stejné, ale čas se může lišit. Výsledek za 139 dní, když počítáte v milisekundách. (java)

Doporučuji nepoužívat milis, ale k výpočtu použít dny.

Něco jako

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

nebo

/**
     *
     * @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;
        }
    }

Poznámka:První příklad je o něco pomalejší než druhý, ale pokud jde jen o malé rozdíly, je zanedbatelný.



  1. Jak vyplnit prázdnou hodnotu, když v daný den není žádný záznam pomocí MySQL group by

  2. MySQL:Použití dat mezi podmínkami pro výsledky

  3. Jak načíst data z kurzoru v Oracle pomocí For Loop

  4. Jak lze vypustit databázi šablon z PostgreSQL?