Обновите значение jsonb в PostgreSQL с помощью JOOQ

0

Вопрос

В моем проекте Java я использую JOOQ, и я хочу обновить значение JSONB. Но моя сборка потерпела неудачу.

Я написал код:

DSL.using(connection).update(USER_SETTINGS)
                .set(USER_SETTINGS.SETTING_VALUE, field("{\"filtersValue\":{\"page\":0,\"size\":100}, \"visibleCount\":100}", JSONB.class))
                .where(USER_SETTINGS.USER_ID.eq(98383L))
                .execute();

enter image description here

и я получил следующее сообщение:

org.jooq.exception.DataAccessException: 
SQL [update "sbcm_sys"."user_settings" set "setting_value" = "filtersValue":{"page":0,"size":100, "visibleCount":100} where "sbcm_sys"."user_settings"."user_id" = ?]; ERROR: syntax err
or at or near ":"
  Position: 71
Caused by: org.postgresql.util.PSQLException: 
ERROR: syntax error at or near ":"
  Position: 71

Где я допустил ошибку?

java jooq jsonb postgresql
2021-11-22 08:59:51
1

Лучший ответ

1

Вы используетеDSL.field(String), который используется для простых шаблонов SQL, когда вы намеревались использоватьDSL.val(String), который используется для привязки значений.

Смотрите также это сообщение в блоге для получения дополнительных разъяснений: https://blog.jooq.org/whats-a-string-in-the-jooq-api/

2021-11-22 10:29:00

На других языках

Эта страница на других языках

Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................