Возвращается из Postgres timstamptz всегда в формате UTC.JAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Возвращается из Postgres timstamptz всегда в формате UTC.

Сообщение Anonymous »

Я немного запутался.

У меня есть приложение Spring Boot (Spring Boot версии 4.0.1).

Есть простой DDL:

Код: Выделить всё

create table foo (
id serial not null primary key,
dt timestamptz not null
);
И сущность:

Код: Выделить всё

@Getter
@Setter
@Entity
public class Foo {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
private OffsetDateTime dt;

public Foo() {}

public Foo(OffsetDateTime dt) {
this.dt = dt;
}
}
У меня есть API:

Код: Выделить всё

@GetMapping
public List getAll() {
return repository.findAll();
}
После вызова API я ожидаю, что поле dt будет возвращено в часовом поясе, указанном JVM (или из -Duser.timezone). Но он всегда возвращается в формате UTC.

Я пытался использовать ?serverTimezone в URL-адресе соединения JDBC, установить -Duser.timezone, использовать явно заданный часовой пояс в Postgres (используя переменные docker и среды TZ и PGTZ). Но ничего.
Наверное, я неправильно понимаю, как это должно работать. Я ожидал, что время, возвращаемое из БД, будет находиться в часовом поясе, указанном клиентом драйвера JDBC (в данном случае JVM).

Подробнее здесь: https://stackoverflow.com/questions/798 ... ays-in-utc
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»