java - Hibernate如何處理參數數量不定的實體類
問題描述
假設一個對象Object有若干個參數,而參數的名稱和數量是不確定的,想知道這種情況下數據表應該怎么設計才會更適合Hibernate去操作.之前我弄過一個方案(想聽大神吐槽):一共用到了兩個表:一個是tab表,一個是tabmeta表,并將tabmeta表中的tid參照tab的id創建外鍵(其實不想在數據庫中創建出這個關系,想在程序或者DAO層實現這樣的關系).創建出對應的實體類(用InteliJ IDEA的逆向工程直接通過表生成的):
//tab的實體類@Entity@Table(name = 'tab', schema = 'springfkhibernate', catalog = '')public class TabEntity { private int id; private String name; private Map<Object, TabmetaEntity> tabmetasById; //省略一些該有的函數和geter seter @MapKey(name = 'metakey') @OneToMany(mappedBy = 'tabByTid') public Map<Object, TabmetaEntity> getTabmetasById() {return tabmetasById; } public void setTabmetasById(Map<Object, TabmetaEntity> tabmetasById) {this.tabmetasById = tabmetasById; }}//tabmeta的實體類@Entity@Table(name = 'tabmeta', schema = 'springfkhibernate', catalog = '')public class TabmetaEntity { private int id; private String metakey; private String metavalue; //省略該有的getter和setter}
生成的時候的參數:但是這樣會搞出兩個實體類出來,一個是TabEntity,一個是TabValueEntity,強迫癥表示不爽啊,本來這兩個表描述的是一個實體的問題,而不是兩個具有一對多的兩個對象的關系.現在我想問一下能不能實現在TabEntity中準備一個類型為(Hash)Map的變量metas,專門用來存儲這些不確定的參數,這樣就只有一個實體類了.但是這樣的話,數據在回存數據庫的時候又應該怎么實現呢?現在這種方式產生的實體類如果想要訪問其中的某一個不定參數的話,需要:TabDao.getEntity(...).getTabmetasById().get(’somekey’).getMetaValue()來實現,但是如果把這兩個表的數據理解成一個實體的數據的話就應該這么實現:TabDao.getEntity(...).getMeta(’somekey’)不知道大神有沒有針對這方面的建議....另外想問問大神在IDEA的關系創建的對話框中每一項參數會產生怎樣的影響.
困惑比較大,還望大神們賜教!
問題解答
回答1:又到了自問自答的環節....如果說實現我上面說的那種方式,還要實現LazyLoad,IDEA自動生成基本上是沒戲的....那個生成的功能是不包括建立非對象之間的關系的,如果需要建立,只能自己去改映射文件.先把那個tab表的實體類生成出來,然后在tab的實體類中添加一個Map類型的對象(具體映射的類型看另一個表的字段數據類型),生成對應的geter和seter函數.然后就是map文件:
<map name='values' table='tabmeta'> <key column='tid' foreign-key='id'/><!--虛擬外鍵:誰和誰相等代表關系--> <index column='meta_key' type='string'/><!--Map的Key是誰--> <element column='meta_value' type='double'/><!--Map的Value是誰--></map>
相關文章:
1. 視頻文件不能播放,怎么辦?2. 前端 - 誰來解釋下這兩個 CSS selector 區別3. javascript - 求幫助 , ATOM不顯示界面!!!!4. javascript - ios返回不執行js怎么解決?5. python - 爬蟲模擬登錄后,爬取csdn后臺文章列表遇到的問題6. html5 - HTML代碼中的文字亂碼是怎么回事?7. python bottle跑起來以后,定時執行的任務為什么每次都重復(多)執行一次?8. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處9. javascript - vue2如何獲取v-model變量名10. javascript - angular使從elastichearch中取出的文本高亮顯示,如圖所示
