[问题] 不同框架实作同一个JSR差异

楼主: cyclone350 (老子我最神)   2014-07-30 14:37:14
大家好
最近有在测试新的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 ....
还请高手解惑或是帮忙解答一下,谢谢
作者: phstudy (study)   2014-07-30 18:09:00
你是对的,JPA确实就只是个SPEC, 实作还是要看各家的
楼主: cyclone350 (老子我最神)   2014-07-30 19:03:00
不是要经过相容性测试吗?从这个丽子我不知道哪边相容了 @@
作者: wildrush   2014-07-30 20:30:00
可能要确认该框架实作了哪个版本的JSR
作者: luoqr (.....)   2014-07-30 22:12:00
旧版不是Entity可以跑?照概念来看em.create..执行取到的东西应该会被em列管才对非Entity的话...em是怎么管理它的 @@?
作者: phstudy (study)   2014-07-30 23:10:00
刚认真看了一下,你的model跟你的db字段对不起来啊另外你的query里面也没捞id例子在这边 https://github.com/phstudy/JPANativeQuery
楼主: cyclone350 (老子我最神)   2014-07-30 23:35:00
我暸phstudy的意思,在hibrenate只能捞到entity但是却不能捞出dto,而另外一个framework kodo却可以不知道phstudy是否了解我的意思 !!我所谓的不能,是指说 createNativeQuery 方法不能
作者: phstudy (study)   2014-07-30 23:40:00
我懂,另外JPA2.1里面有这句话: When an entity is to bereturned from a native query, the SQL statement shouldselect all of the columns that are mapped to theentity object.我觉得这算是某Framework自己的特殊功能看样子我搞错你的问题了XD 来修正一下修正好了 :D 参考一下吧

Links booklink

Contact Us: admin [ a t ] ucptt.com