[問題] hibernate 新手問題
最近利用空檔在練習 hibernate (進度緩慢)
因為這問題想了很久,在網路上也不知道關鍵字是甚麼,看了一些 document 也沒頭緒
所以就上來請教各位前輩
我使用的是 spring + hibernate
首先 hibernate 是一個 ORM framework。
如果我們要 select,利用他提供的 libery 就可以直接存取。
要查詢物件也很簡單,例如:
String hql = "from people";
List<people> peoplesss = this.getSessionTemplete().creatQuery(hql).list();
就可以得到這些Entity,相反的 insert 跟 delete 也類似
問題來啦,假設這是美食獵人世界的系統資料庫,如果只是用 from people,
則這個 List 的 size 可能好幾百億,這下不得了。
不過 hibernate 可以設定 pageSize 跟 pageNum 之類的東西,可以設定一次只拿到 n 筆
問題是 spring 提供的 hibernateTemplete 並沒有這個功能‧‧‧
好家在 google 大神跟我說 hibernateTemplete 有一個 callbackHibernate 方法,
所以此問題就解決了。
接下來要設定關聯資料庫
假設美食世界的人有三種,美食獵人,廚師,一般人,
我們可以增加一個 Table 名為 FOOD_TAG。
並且在 PEOPLE 的 table 增加一個 FK 名為 TAG,對應到 FOOD_TAG 的 PK,
所以我們在 PEOPLE 的 Entity 要設定一個 @ManyToOne 對應到 FOOD_TAG
而 FOOD_TAG 的 Entity 要設定一個 @OneToMany 對應到 PEOPLE。
這樣想要知道屬於美食獵人Tag的人有哪些,只需要從 FOOD_TAG 的 Entity 拿到 people
的 list 就好了。
問題來了,如果我只需要拿到 Tag 的名稱,例如:
Tag tag = getHibernateTemplete().
createQuery("from tag t where t.name = '一般人'");
String tagName = tag.getName();
那這樣還需要抓取 people List 嗎?
還好可以設定 fetch lazy 來解決這問題,我可以等到要 getPeopleList 時才 query
(不過 session 不能關啦,或是要設定其他的)
不過又有問題了,假設我要 getPeopleList,他會一次給我全部的人,
假設分類在 "一般人" 的 People 有 60 億人,那我的 memory 豈不就爆掉了。
於是我翻書,請 google 搜尋此類問題,皆找不到 OneToMany 的限制用法
我想要 OneToMany 可以想一般平常的 query 可以設定 maxSize 或是 page 的概念
不過 google 似乎也沒找到 ...
另外本來想用 FK 當 where 條件當 query,然後就用一開始的方法。
可是在 entity 的 FK 是隱藏的 (joinColumn)。
想請問有沒有此類方法可以解? Annotation 要怎麼設定才會有這樣的效果
看過很多網站都沒講這問題
有看到一個網頁有用 @Size(max=30) 這樣,但是我的專案根本沒有 @Size
另外還有一個問題,我還沒自己試過,請問 Entity 的 @oneToMany 之類的會有
連鎖效應嗎?
例如 A -> B -> C -> D <- A
A 對 B , 一對多
B 對 C , 一對多
C 對 D , 一對多
A 對 D , 一對多
假設我都是 fetch eager 的話
會在 query A 的時候,把 B 一起 query。
因為 B -> C,hibernate 會順便 query C 嗎?
然後 C -> D 再 query D ?
假設我要拿到D
就直接 a.getB().get(0).getC().get(0).getD() ?
這樣找一個資料,數量級大一點的話,hibernate 不就死掉了嗎?
文有點長,看不董跟我說我再解釋一下,文筆有點不順。
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 114.198.167.187
推
01/09 00:21, , 1F
01/09 00:21, 1F
推
01/09 00:25, , 2F
01/09 00:25, 2F
推
01/09 01:34, , 3F
01/09 01:34, 3F
→
01/09 01:37, , 4F
01/09 01:37, 4F
推
01/09 01:40, , 5F
01/09 01:40, 5F
推
01/09 09:41, , 6F
01/09 09:41, 6F
→
01/09 09:53, , 7F
01/09 09:53, 7F
→
01/09 09:54, , 8F
01/09 09:54, 8F
推
01/09 10:38, , 9F
01/09 10:38, 9F
→
01/09 10:41, , 10F
01/09 10:41, 10F
推
01/09 10:45, , 11F
01/09 10:45, 11F
→
01/09 10:47, , 12F
01/09 10:47, 12F
→
01/09 11:47, , 13F
01/09 11:47, 13F
→
01/09 18:04, , 14F
01/09 18:04, 14F
→
01/09 18:12, , 15F
01/09 18:12, 15F
→
01/09 18:14, , 16F
01/09 18:14, 16F
推
01/10 01:09, , 17F
01/10 01:09, 17F
推
01/10 01:12, , 18F
01/10 01:12, 18F
推
01/10 01:14, , 19F
01/10 01:14, 19F
推
01/10 01:17, , 20F
01/10 01:17, 20F
→
01/10 11:38, , 21F
01/10 11:38, 21F
→
01/10 11:40, , 22F
01/10 11:40, 22F
討論串 (同標題文章)