[問題] 不同框架實作同一個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