亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

使用輸入列表獲取實體對象列表:Spring Data JPA - Hibernate

使用輸入列表獲取實體對象列表:Spring Data JPA - Hibernate

至尊寶的傳說 2021-12-10 10:08:19
我有一個 APIObjects 列表List<APIObjects> apiObjectList作為我的 API 的輸入(通過 HTTP-Post),我需要檢查這個對象中的所有參數是否存在于我的數據庫中DatabaseObject.java@Data@Builder@NoArgsConstructor@AllArgsConstructor@Entity@Table(name = "my_table")public class DatabaseObject {    @Id    @GeneratedValue(strategy = GenerationType.IDENTITY)    Long id;    @Column(name = "name")    String name;    @Column(name = "group_id")    String groupId;    @Column(name = "artifact_id")    String artifactId;    @Column(name = "version")    String version; }APIObject.java@Data@NoArgsConstructor@AllArgsConstructor@Builderpublic class APIObject{    private String groupId;    private String artifactId;    private String version;}在我Repository Interface我有這樣的方法List<DatabaseObject> findByGroupIdAndArtifactIdAndVersionIn (List<APIobject> apiList);但我得到這個例外Caused by: java.lang.IllegalArgumentException: No parameter available for part artifactId SIMPLE_PROPERTY (1): [Is, Equals].如何為此編寫Spring-data-JPA方法?所有三個參數都應該匹配(groupid, artifactid and version)
查看完整描述

2 回答

?
Helenr

TA貢獻1780條經驗 獲得超4個贊

如果要從方法名稱創建查詢,則應更改存儲庫方法:

List<DatabaseObject> findByGroupIdAndArtifactIdAndVersion(String groupId, String artifactId, String version);

或使用In關鍵字:

List<DatabaseObject> findByAPIobjectIn(Collection<APIObject> apis)

有關更多詳細信息,請參閱查詢創建


查看完整回答
反對 回復 2021-12-10
?
有只小跳蛙

TA貢獻1824條經驗 獲得超8個贊

嘗試使用Query by Example技術。在您的情況下,解決方案可能如下所示:


DatabaseObject dbObject = new DatabaseObject(apiObject.getGroupId(), ...);

Iterable<DatabaseObject> dbObjects = DatabaseObjectRepository.findAll(Example.of(dbObject));


查看完整回答
反對 回復 2021-12-10
  • 2 回答
  • 0 關注
  • 331 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號