近期項目中需要 關(guān)聯(lián) 幾張表再把字段轉(zhuǎn)出來,在這里記錄以下,我感覺網(wǎng)上寫的都不太規(guī)范和清晰。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
@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; } |
需要聲明接口:
1
2
3
4
5
6
7
|
@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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://www.cnblogs.com/1994jinnan/p/13401320.html