作者cyclone350 (老子我最神)
看板java
标题[问题] 不同框架实作同一个JSR差异
时间Wed Jul 30 14:37:14 2014
大家好
最近有在测试新的framework
不过有一个问题
我的旧版程式使用 JPA,新的程式也是使用 JPA
但是同一段程式码在旧版的可以 run,在新版的却会出现 Exception...
JPA 不是一个 java 标准吗?
所以实作内容不是要遵照标准规格去做吗?
如果同一个 JSR 再不同的framework实作会产生不同的效果,那还能称作标准吗?
还是我对 JSR 标准有误解?
实际例子是这样的
我必须要做一个 native query,且对应的结果必须对应到一个非 entity 的 java bean.
假设 java bean 长这样
public class TestJavaBean {
private String name;
private String size;
// getter and setter
...
}
在旧版程式会这样写 (em = entityManager)
Query q = em.createNativeQuery("select pname as name, psize as size from
product", TestJavaBean.class);
List<TestJavaBean> list = (List<TestJavaBean>) q.getResultList();
但是我使用新的 framework 之後 (hibernate4),同样的程式码却会跳出 exception.
"Unknown entity: myPackage.TestJavaBean"
似乎意味着 TestJavaBean 必须是 entity class.
网路上有找到改法
https://forum.hibernate.org/viewtopic.php?f=1&t=994817
这是原作者自问自答
除了这个例子外,还有其他明明都是同一个 annotation (例如 @GenerateValue),两个
framework行为却不一样
究竟是 framework 不遵照 JSR 标准,还是说 JSR 标准就只是定个表面,却没限制行为
?
最後,其实第一个例子还是没有解,照了原作者提供的方式,会跳出 exception
HIbernate Mapping Exception: PropertyNotFoundException: Could not find a
setter NAME
可能我的 set method 要写成 setNAME 而不是 setName ....
还请高手解惑或是帮忙解答一下,谢谢
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 61.218.64.133
※ 文章网址: http://webptt.com/cn.aspx?n=bbs/java/M.1406702238.A.982.html
1F:推 phstudy:你是对的,JPA确实就只是个SPEC, 实作还是要看各家的 07/30 18:09
2F:→ cyclone350:不是要经过相容性测试吗? 07/30 19:03
3F:→ cyclone350:从这个丽子我不知道哪边相容了 @@ 07/30 19:04
4F:推 wildrush:可能要确认该框架实作了哪个版本的JSR 07/30 20:30
5F:推 luoqr:旧版不是Entity可以跑? 07/30 22:12
6F:→ luoqr:照概念来看em.create..执行取到的东西应该会被em列管才对 07/30 22:14
7F:→ luoqr:非Entity的话...em是怎麽管理它的 @@? 07/30 22:14
8F:推 phstudy:刚认真看了一下,你的model跟你的db栏位对不起来啊 07/30 23:10
9F:→ phstudy:另外你的query里面也没捞id 07/30 23:11
11F:→ cyclone350:我了phstudy的意思,在hibrenate只能捞到entity 07/30 23:35
12F:→ cyclone350:但是却不能捞出dto,而另外一个framework kodo却可以 07/30 23:36
13F:→ cyclone350:不知道phstudy是否了解我的意思 !! 07/30 23:37
14F:→ cyclone350:我所谓的不能,是指说 createNativeQuery 方法不能 07/30 23:39
15F:推 phstudy:我懂,另外JPA2.1里面有这句话: When an entity is to be 07/30 23:40
16F:→ phstudy:returned from a native query, the SQL statement should 07/30 23:41
17F:→ phstudy:select all of the columns that are mapped to the 07/30 23:41
18F:→ phstudy:entity object. 07/30 23:41
19F:推 phstudy:我觉得这算是某Framework自己的特殊功能 07/30 23:45
20F:推 phstudy:看样子我搞错你的问题了XD 来修正一下 07/30 23:50
21F:推 phstudy:修正好了 :D 参考一下吧 07/31 00:19