У меня есть таблица user_asset в PostgreSQL с идентификатором столбца, user_id, кодом (тип — целое число, ограничение — user_asset_code_unique).
user_asset
id user_id code
1 97 7752
2 98 7753
3 99 7754
@Repository
public interface AssetRepository extends JpaRepository {}
@Entity
@Getter
@Builder
@NoArgsConstructor
@AllArgsConstructor
@Table(name = "user_asset", schema = "public")
public class UserAsset {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Integer id;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "user_id")
private User user;
@OneToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "code")
private MPID mpid;
}
private final AssetRepository assetRepository;
@Transactional
public UserAssetResponse update(UserAssetRequest dto){
//some code here
User user = userRepository.findById(dto.getID());
addAssets(user, dto.getAssets());
}
private void addAssets(User user, List assets){
List newAssets = mpidRepository.findAllById(assets).stream()
.map(item -> UserAsset.builder().user(user).mpid(item).build())
.collect(Collectors.toList());
assetRepository.saveAll(newAssets);
}
От почтальона я отправляю:
{
"id": 97,
"assets": [7753,7754]
}
Как вы видите из примера выше базы данных:
id user_id code
1 97 7752
и я пытаюсь обновить коды [7753,7754]
Когда я пытаюсь обновить UserAssetResponse и установить существующий код столбец я получил исключение.
В Postman я вижу:
500 Internal server error
{
"message": "could not execute statement; SQL [n/a]; constraint [user_asset_code_unique]; nested exception is org.hibernate.exception.ConstraintViolationException: could not execute statement"
}
В IDEA ошибка:
o.h.engine.jdbc.spi.SqlExceptionHelper : ERROR: duplicate key value violates unique constraint "user_asset_code_unique"
Detail: Key (mpid_id)=(7753) already exists.
Я понимаю, что это произошло из-за ограничения столбца code [user_asset_code_unique].
Проблема в том, что я не знаю, где произошло это исключение, и как обработать это исключение.
Я пробую это решение и знаю, что перехват исключения неверен, но это не помогает.
try{
assetRepository.saveAll(newAssets);
}catch (Exception e){
e.printStackTrace();
}
Подробнее здесь: https://stackoverflow.com/questions/786 ... constraint
Как обрабатывать исключение «ОШИБКА: повторяющееся значение ключа нарушает уникальное ограничение» в Spring Boot ⇐ JAVA
Программисты JAVA общаются здесь
1719635383
Anonymous
У меня есть таблица user_asset в PostgreSQL с идентификатором столбца, user_id, кодом (тип — целое число, ограничение — user_asset_code_unique).
user_asset
id user_id code
1 97 7752
2 98 7753
3 99 7754
@Repository
public interface AssetRepository extends JpaRepository {}
@Entity
@Getter
@Builder
@NoArgsConstructor
@AllArgsConstructor
@Table(name = "user_asset", schema = "public")
public class UserAsset {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Integer id;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "user_id")
private User user;
@OneToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "code")
private MPID mpid;
}
private final AssetRepository assetRepository;
@Transactional
public UserAssetResponse update(UserAssetRequest dto){
//some code here
User user = userRepository.findById(dto.getID());
addAssets(user, dto.getAssets());
}
private void addAssets(User user, List assets){
List newAssets = mpidRepository.findAllById(assets).stream()
.map(item -> UserAsset.builder().user(user).mpid(item).build())
.collect(Collectors.toList());
assetRepository.saveAll(newAssets);
}
От почтальона я отправляю:
{
"id": 97,
"assets": [7753,7754]
}
Как вы видите из примера выше базы данных:
id user_id code
1 97 7752
и я пытаюсь обновить коды [7753,7754]
Когда я пытаюсь обновить [b]UserAssetResponse[/b] и установить существующий код [b]столбец[/b] я получил исключение.
В Postman я вижу:
500 Internal server error
{
"message": "could not execute statement; SQL [n/a]; constraint [user_asset_code_unique]; nested exception is org.hibernate.exception.ConstraintViolationException: could not execute statement"
}
В IDEA ошибка:
o.h.engine.jdbc.spi.SqlExceptionHelper : ERROR: duplicate key value violates unique constraint "user_asset_code_unique"
Detail: Key (mpid_id)=(7753) already exists.
Я понимаю, что это произошло из-за ограничения столбца [b]code[/b] [user_asset_code_unique].
Проблема в том, что я не знаю, где произошло это исключение, и как обработать это исключение.
Я пробую это решение и знаю, что перехват исключения неверен, но это не помогает.
try{
assetRepository.saveAll(newAssets);
}catch (Exception e){
e.printStackTrace();
}
Подробнее здесь: [url]https://stackoverflow.com/questions/78684586/how-to-handle-exception-error-duplicate-key-value-violates-unique-constraint[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия