Как вставить массив композитного типа PostgreSQL с помощью JDBCClient SpringbootJAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Как вставить массив композитного типа PostgreSQL с помощью JDBCClient Springboot

Сообщение Anonymous »

Я пытаюсь сохранить массив композитного типа, который не имеет отношений, просто данные, которые я хочу сохранить и повторно использовать во время выполнения, поэтому я не использую несколько строк для хранения этих данных.

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

shop_item
postgresql comspoite type:

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

CREATE TYPE shop_item AS (
id                    VARCHAR(255),
quantity              INTEGER,
quantity_multiplier   INTEGER,
price                 DECIMAL(4, 2)
);
< /code>
shop_orders
Postgresql Таблица:

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

CREATE TABLE IF NOT EXISTS shop_orders (
guild_id     BIGINT        NOT NULL,
user_id      BIGINT        NOT NULL,
shop_items   shop_item[]   NOT NULL,

PRIMARY KEY (guild_id, user_id),
FOREIGN KEY (guild_id) REFERENCES guild_config (guild_id)
ON DELETE CASCADE
);
< /code>
Java SpringBoot DAO Method & Query:
@Override
public void upsert(long guildId, @NotNull ShopOrder shopOrder) {
jdbc.sql("""
INSERT INTO shop_orders (guild_id, user_id, shop_items)
VALUES (?, ?, ?::shop_item[])
ON CONFLICT (guild_id, user_id)
DO UPDATE SET shop_items = EXCLUDED.shop_items;
""")
.param(1, guildId)
.param(2, shopOrder.getUserId())
.param(3, shopOrder.getShopItems())
.update();
}
< /code>
shopOrder.getShopItems()
имеет список типов .

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

ShopItem.class
Sing:

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

public class ShopItem {
private String id;
private int quantity;
private int quantityMultiplier;
private double price;
}
< /code>
The issue I believe is that JdbcClient can't map the List of ShopItem(s) to the one declared as shop_item in the database, But I tried type casting, using ARRAY[?]::shop_item[]
в качестве параметра, он всегда допускает ошибки, такие как «Не могу поднять на типы. Аррейт» или неверные элементы

Подробнее здесь: https://stackoverflow.com/questions/794 ... jdbcclient
Реклама
Ответить Пред. темаСлед. тема

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

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

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

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

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Параметр композитного типа в PostgreSQL с использованием npgsql,
    Anonymous » » в форуме C#
    0 Ответы
    14 Просмотры
    Последнее сообщение Anonymous
  • Параметр композитного типа в PostgreSQL с использованием npgsql,
    Anonymous » » в форуме C#
    0 Ответы
    8 Просмотры
    Последнее сообщение Anonymous
  • Параметр композитного типа в PostgreSQL с использованием npgsql,
    Anonymous » » в форуме C#
    0 Ответы
    12 Просмотры
    Последнее сообщение Anonymous
  • Как настроить ConversionService, используемый JdbcClient?
    Anonymous » » в форуме JAVA
    0 Ответы
    15 Просмотры
    Последнее сообщение Anonymous
  • Jdbcclient apportmentspec innd несколько заполнителей с одним параметром
    Anonymous » » в форуме JAVA
    0 Ответы
    4 Просмотры
    Последнее сообщение Anonymous

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