java - JPA 中自定义对象和原生对象属性名不一致怎么解决?
PHPz
PHPz 2017-04-18 10:56:49
0
1
534

有如下段代码 其中person是jpa的entity对象,personResult是自定义对象

@Query(select new com.xx.yy.PersonResult(p.id,p.name,p.age) from Person p)
 List<PersonResult> findPersonResult();

这样执行是可以的,但是如果我其中的personResult对象中的id是叫personId,上面的代码该如何改?

我用过

@Query(select new com.xx.yy.PersonResult(p.id as personId,p.name,p.age) from Person p)
 List<PersonResult> findPersonResult();

会报错,是不是jpql new对象的时候不支持别名吗?

PHPz
PHPz

学习是最好的投资!

全部回覆(1)
阿神

你的程式碼

@Query(select new com.xx.yy.PersonResult(p.id as personId,p.name,p.age) from Person p)
 List<PersonResult> findPersonResult();

你把as去掉就可以了,jpa是不支持這種語法的。



關於你的問題:Entity 和你自訂的類別屬性名稱不一樣的問題,你大可不必擔心,使用select new xx.xx.PersonResult(p.id,p.name.p.age) 语法时,jpa不会关心真实的字段叫什么名字,只要字段类型一致就可以了,因为这里采用是Java的构造函数。调用构造函数时只需要关心需要传入几个参数以及参数的类型

看下我程式碼,這樣會直覺一點

@Query("select new com.zfxiao.pojo.AnnotherPerson(p.id,p.name,p.age) from Person p ")
List<AnnotherPerson> findAnnotherPerson()

AnnotherPerson的建構子

public AnnotherPerson(Long personId, String name, Integer age) {
    this.personId = personId;
    this.name = name;
    this.age = age;
}
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!