[問題] 不同框架實作同一個JSR差異

看板java作者 (老子我最神)時間10年前 (2014/07/30 14:37), 編輯推噓9(9012)
留言21則, 4人參與, 最新討論串1/2 (看更多)
大家好 最近有在測試新的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://www.ptt.cc/bbs/java/M.1406702238.A.982.html

07/30 18:09, , 1F
你是對的,JPA確實就只是個SPEC, 實作還是要看各家的
07/30 18:09, 1F

07/30 19:03, , 2F
不是要經過相容性測試嗎?
07/30 19:03, 2F

07/30 19:04, , 3F
從這個麗子我不知道哪邊相容了 @@
07/30 19:04, 3F

07/30 20:30, , 4F
可能要確認該框架實作了哪個版本的JSR
07/30 20:30, 4F

07/30 22:12, , 5F
舊版不是Entity可以跑?
07/30 22:12, 5F

07/30 22:14, , 6F
照概念來看em.create..執行取到的東西應該會被em列管才對
07/30 22:14, 6F

07/30 22:14, , 7F
非Entity的話...em是怎麼管理它的 @@?
07/30 22:14, 7F

07/30 23:10, , 8F
剛認真看了一下,你的model跟你的db欄位對不起來啊
07/30 23:10, 8F

07/30 23:11, , 9F
另外你的query裡面也沒撈id
07/30 23:11, 9F

07/30 23:21, , 10F
07/30 23:21, 10F

07/30 23:35, , 11F
我暸phstudy的意思,在hibrenate只能撈到entity
07/30 23:35, 11F

07/30 23:36, , 12F
但是卻不能撈出dto,而另外一個framework kodo卻可以
07/30 23:36, 12F

07/30 23:37, , 13F
不知道phstudy是否了解我的意思 !!
07/30 23:37, 13F

07/30 23:39, , 14F
我所謂的不能,是指說 createNativeQuery 方法不能
07/30 23:39, 14F

07/30 23:40, , 15F
我懂,另外JPA2.1裡面有這句話: When an entity is to be
07/30 23:40, 15F

07/30 23:41, , 16F
returned from a native query, the SQL statement should
07/30 23:41, 16F

07/30 23:41, , 17F
select all of the columns that are mapped to the
07/30 23:41, 17F

07/30 23:41, , 18F
entity object.
07/30 23:41, 18F

07/30 23:45, , 19F
我覺得這算是某Framework自己的特殊功能
07/30 23:45, 19F

07/30 23:50, , 20F
看樣子我搞錯你的問題了XD 來修正一下
07/30 23:50, 20F

07/31 00:19, , 21F
修正好了 :D 參考一下吧
07/31 00:19, 21F
文章代碼(AID): #1Js9AUc2 (java)
文章代碼(AID): #1Js9AUc2 (java)