У меня есть приложение 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;
}
}
Код: Выделить всё
@GetMapping
public List getAll() {
return repository.findAll();
}
Я пытался использовать ?serverTimezone в URL-адресе соединения JDBC, установить -Duser.timezone, использовать явно заданный часовой пояс в Postgres (используя переменные docker и среды TZ и PGTZ). Но ничего.
Наверное, я неправильно понимаю, как это должно работать. Я ожидал, что время, возвращаемое из БД, будет находиться в часовом поясе, указанном клиентом драйвера JDBC (в данном случае JVM).
Подробнее здесь: https://stackoverflow.com/questions/798 ... ays-in-utc
Мобильная версия