Spring Data Jpa實現(xiàn)自定義repository轉DTO
更新時間:2020年08月05日 09:22:06 作者:哎喲媽耶
這篇文章主要介紹了Spring Data Jpa實現(xiàn)自定義repository轉DTO,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
近期項目中需要 關聯(lián) 幾張表再把字段轉出來,在這里記錄以下,我感覺網(wǎng)上寫的都不太規(guī)范和清晰。
@Entity @SqlResultSetMapping( name="TestMapping", entities = { @EntityResult( entityClass = com.xxx.xx.data.model.TestEntity.class, fields = { @FieldResult(name="id",column="id"), @FieldResult(name="localTime",column="time"), @FieldResult(name="maximumAppointment",column="maxAppointment"), } ) } ) @NamedNativeQuery(name="getTestQuery", query="select tableC.id as id,tableB.time,tableC.maximumAppointment as maxAppointment from tableB " + " inner join tableA on tableA.id = tableB.tableAId " + " inner join tableC on tableB.id = tableC.tableBId " + " inner join custom on custom.id = tableA.customId " + "where " + " tableA.locationId = :locationId" + " and custom.id = :customId" + " and tableB.deleted = false ", resultSetMapping="TestMapping") @Data public class TestEntity { @Id private String id; private LocalTime localTime; private Integer maximumAppointment; }
需要聲明接口:
@Repository public interface TestEntityRepository extends JpaRepository<TestEntity,String> { @Query(name="getTestQuery") List<TestEntity> getTestQuery(String locationId, String customId); }
若不想聲明接口,那可以用EntityManager 來實現(xiàn)。
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
詳解maven的setting配置文件中mirror和repository的區(qū)別
這篇文章主要介紹了詳解maven的setting配置文件中mirror和repository的區(qū)別,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12