av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

java - Hibernate如何處理參數數量不定的實體類

瀏覽:121日期:2023-12-01 18:30:50

問題描述

假設一個對象Object有若干個參數,而參數的名稱和數量是不確定的,想知道這種情況下數據表應該怎么設計才會更適合Hibernate去操作.之前我弄過一個方案(想聽大神吐槽):一共用到了兩個表:一個是tab表,一個是tabmeta表,并將tabmeta表中的tid參照tab的id創建外鍵(其實不想在數據庫中創建出這個關系,想在程序或者DAO層實現這樣的關系).java - Hibernate如何處理參數數量不定的實體類創建出對應的實體類(用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}

生成的時候的參數:java - Hibernate如何處理參數數量不定的實體類但是這樣會搞出兩個實體類出來,一個是TabEntity,一個是TabValueEntity,強迫癥表示不爽啊,本來這兩個表描述的是一個實體的問題,而不是兩個具有一對多的兩個對象的關系.現在我想問一下能不能實現在TabEntity中準備一個類型為(Hash)Map的變量metas,專門用來存儲這些不確定的參數,這樣就只有一個實體類了.但是這樣的話,數據在回存數據庫的時候又應該怎么實現呢?現在這種方式產生的實體類如果想要訪問其中的某一個不定參數的話,需要:TabDao.getEntity(...).getTabmetasById().get(’somekey’).getMetaValue()來實現,但是如果把這兩個表的數據理解成一個實體的數據的話就應該這么實現:TabDao.getEntity(...).getMeta(’somekey’)不知道大神有沒有針對這方面的建議....另外想問問大神在IDEA的關系創建的對話框中每一項參數會產生怎樣的影響.java - Hibernate如何處理參數數量不定的實體類困惑比較大,還望大神們賜教!

問題解答

回答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>

標簽: java
相關文章:
主站蜘蛛池模板: 日韩视频在线免费观看 | 日日草天天干 | 国产免费又黄又爽又刺激蜜月al | 亚洲视频在线观看 | h片免费在线观看 | 成人久久久久 | 男人的天堂一级片 | 精品日韩一区 | 国产午夜在线 | 久久久久久亚洲精品 | 精品国产视频 | 午夜免费视频 | 久久久久久国产精品 | 亚洲精品一区在线 | 久久精品国产久精国产 | 啪啪网页 | 日日草天天干 | 日韩精品免费在线观看 | 精品欧美乱码久久久久久 | 国产精品欧美一区二区 | 一级毛片网 | 一区二区三区四区免费在线观看 | 国产一级片免费看 | av色站| 国产有码 | 国产美女在线观看 | 一级黄在线观看 | 亚洲欧美国产精品一区二区 | 日韩精品人成在线播放 | 男插女下体视频 | 久久精品美女 | 欧美99久久精品乱码影视 | 欧美成人激情 | 久久免费精品 | 精品国产一区二区三区四区在线 | 国产精品特级毛片一区二区三区 | 中文字幕av一区 | 中文字幕国产 | 一区不卡在线观看 | 网色| 国产精品久久久久久久久污网站 |