Quarkus Reactive PostgreSQL Vert.x — коллекция запросов Long & in()

Я пытаюсь использовать подготовленный запрос с запросом «где xxx in ()», используя параметр Set of Long as:

public static Multi<Item> findAll(PgPool client, Set<Long> ids) {
  Tuple parameter = Tuple.of(ids.toArray(new Long[]{}));
  // Tuple parameter = Tuple.wrap(new ArrayList(ids));
  return client.preparedQuery("SELECT id, name, properties FROM items where id in ($1)").execute(parameter)
      .onItem().transformToMulti(set -> Multi.createFrom().iterable(set))
      .onItem().transform(Item::from);
    }

Но хотя предполагается, что SQL-запрос «in» обрабатывает несколько значений, он работает при передаче массива, выдавая следующее:

io.vertx.core.impl.NoStackTraceThrowable: Parameter at position[0] with class = [[Ljava.lang.Long;] and value = [[Ljava.lang.Long;@1a074753] can not be coerced to the expected class = [java.lang.Number] for encoding.

Передача одного значения работает, но это не цель метода:

  Tuple parameter = Tuple.of(1206756351360216067L);

Каким будет правильный способ обработки набора идентификаторов, чтобы вернуть несколько строк?

Редактировать

В итоге я сделал это:

        Tuple parameter = Tuple.of(ids.toArray(new Long[]{}));

        String query = "with values as (\n" +
                "select unnest(($1)::bigint[]) as id\n" +
                ")\n" +
                "select v.* from values vl " +
                "join items v on v.id = vl.id";

Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
0
1 006
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Измените запрос на:

SELECT id, name, properties FROM items where id = ANY($1)

И тогда вы сможете использовать значение параметра List/Set/Array.

Большой! Не могли бы вы принять ответ?

tsegismont 12.01.2021 15:15

Спасибо. Знаете ли вы, как использовать инверсию этого критерия, по сути, предложение NOT IN? Я пытался использовать != ANY($1), но это работает только в том случае, если в переданном списке есть только 1 значение.

Amaresh Kulkarni 16.02.2023 12:20

ты пробовал NOT (id = ANY ($1)) ?

tsegismont 20.02.2023 11:44

Спасибо, что изучили это, этот вариант не сработал. Я создал отдельный пост SO с дополнительными подробностями, если вы могли бы взглянуть, очень признателен.stackoverflow.com/questions/75509225/…

Amaresh Kulkarni 20.02.2023 13:22

Этот вариант действительно работал. Ошибка, с которой я столкнулся, была связана с другим запросом. Спасибо за вашу помощь

Amaresh Kulkarni 20.02.2023 23:51

Другие вопросы по теме