Oracle
 sql >> Baza danych >  >> RDS >> Oracle

POSTMAN zwraca pola dat ze zmienionymi wartościami

Postman nie dodaje niczego do JSON odpowiedź z serwera. Ta reprezentacja podanej daty została wygenerowana przez serwer i jest problem. Po pierwsze, powinniśmy zacząć od tego, że nie należy używać java.util.Date ponieważ używasz Java8 . Istnieje java.time dostępny pakiet i powinieneś go używać do reprezentowania czasu.

toString metoda z Date class używa domyślnej strefy czasowej systemu do drukowania daty i nie powinieneś jej używać. java.time.LocalDateTime powinien pracować dla Ciebie.

Prawdopodobnie Twoja usługa backendu używa bibliotek do generowania JSON odpowiedź. Na przykład Jackson . Jego konfiguracja może być nieprawidłowa, dlatego widzisz nieprawidłowe daty. Zobacz poniższy kod:

import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.ToString;

import java.io.IOException;
import java.time.LocalDateTime;
import java.time.ZoneOffset;
import java.util.Date;
import java.util.TimeZone;

public class JsonTimeApp {
    public static void main(String[] args) throws IOException {
        LocalDateTime initialDate = LocalDateTime.of(2019, 3, 7, 0, 0, 0);
        LocalDateTime finalDate = LocalDateTime.of(2019, 9, 7, 23, 59, 59);

        ObjectMapper mapper = new ObjectMapper();
        mapper.enable(SerializationFeature.INDENT_OUTPUT);
        mapper.registerModule(new JavaTimeModule());
        mapper.setTimeZone(TimeZone.getTimeZone("GMT"));
        // or mapper.setTimeZone(TimeZone.getTimeZone("Etc/GMT-3"));

        mapper.writeValue(System.out, new Period(initialDate, Date.from(finalDate.toInstant(ZoneOffset.UTC))));
    }
}

@Data
@AllArgsConstructor
@ToString
class Period {

    @JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss")
    private LocalDateTime initialDate;

    @JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss")
    private Date finalDate;
}

Powyższy kod ze strefą czasową ustawioną na GMT wydruki:

{
  "initialDate" : "2019-03-07T00:00:00",
  "finalDate" : "2019-09-07T23:59:59"
}

Ale kiedy zmienimy strefę czasową na Etc/GMT-3 , drukuje:

{
  "initialDate" : "2019-03-07T00:00:00",
  "finalDate" : "2019-09-08T02:59:59"
}

Powinieneś sprawdzić, co jest używane do generowania JSON w Twoim przypadku i odpowiednio skonfiguruj strefę czasową. Zauważ, że dla initialDate nie widzimy tego zachowania, ponieważ użyliśmy java.time.LocalDateTime klasa zamiast Date .



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jak usunąć powtarzające się wiersze w zapytaniu Oracle SQL

  2. Przenieś wartości inne niż NULL w górę w obrębie partycji

  3. Proszę o podanie kodu ceny tylko wtedy, gdy wpisz :=E

  4. Karta sieciowa nie mogła nawiązać połączenia — Oracle 11g

  5. Kiedy oracle zaczęła wspierać górę:wybierz górę? p2_.PRODUCT_ID z PRODUCT?