用hibernate开发时,建好主表后发现有一些配置属性需要添加,而有不想更改主表结构,这是只需要建一个配置表,在主表的model配置中配置上配置表的key和value就行,如:
主表:CREATE TABLE `SKILL_GROUP` (
`ID` int(11) NOT NULL AUTO_INCREMENT,
`SKILL_GROUP` varchar(36) NOT NULL,
`TYPE` int(11) NOT NULL,
`WORK_END_TIME` varchar(10) DEFAULT NULL,
`WORK_START_TIME` varchar(10) DEFAULT NULL,
`SP_ID` varchar(36) DEFAULT NULL,
`USER_ID` int(11) DEFAULT NULL,
PRIMARY KEY (`ID`),
UNIQUE KEY `SP_ID` (`SP_ID`),
KEY `FK508C0AD1AA67812B` (`SP_ID`),
KEY `FK508C0AD11DD0822B` (`USER_ID`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 CHECKSUM=1 DELAY_KEY_WRITE=1 ROW_FORMAT=DYNAMIC;
配置表: CREATE TABLE `SKILL_CONFIGURATION` (
`CONFIG_KEY` varchar(36) NOT NULL,
`CONFIG_VALUE` varchar(36) NOT NULL,
`SKILL_GROUP_ID` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
在主表的model中配置上(TskillGroup):
private Map
@ElementCollection(fetch=FetchType.EAGER)
@MapKeyColumn(name = "CONFIG_KEY") //配置属性的key值
@Column(name = "CONFIG_VALUE", length = 290) //配置属性的值
@CollectionTable(name = "SKILL_CONFIGURATION", //配置表表名
joinColumns = @JoinColumn(name = "SKILL_GROUP_ID")) //存放主表的主键
public Map
return configMap;
}
public void setConfigMap(Map
this.configMap = configMap;
}
在对对象TskillGroup进行增删改查时,用以下方法同步配置表属性:
TskillGroup tsg = new TskillGroup();
......把对象属性set进去
添加对象:skillGroupDao.save(tsg);
同步配置属性表数据:tsg.getConfigMap().put(配置属性的key,配置属性值 );
修改对象:TskillGroup tsg = skillGroupDao.get(TskillGroup.class, skillGroup.getId());
.....把新修改的值set到对象中
同步配置属性表数据:tsg.getConfigMap().put(配置属性的key,配置属性更新的值 );
删除对象:TskillGroup tsg = skillGroupDao.get(TskillGroup.class, sgId);
删除此对象对应的所有配置属性:tsg.getConfigMap().clear();
查询对象:List
循环list得到TskillGroup对象tsg
查出tsg对象对应的配置属性:tsg.getConfigMap().get(配置属性的key)
Hibernate关联管理配置表
发表于:2017-01-09
作者:网络转载
来源:
- 周排行
- 月排行
-   Spring配置代理事务管理配置
-   配置文件的构成和管理
-   iOS VPN开发的配置和管理
-   软件配置管理之配置管理计划
-   软件配置管理中的SVN
-   配置管理规范(配置项标识和配置审计...
-   本地多用户下git使用ssh管理配置
-   iOS VPN开发的配置和管理
-   使用Vundle管理配置Vim基本插件
-   Spring任务调度配置及使用
-   配置文件的构成和管理
-   Spring配置代理事务管理配置
-   配置管理规范-互联网配置管理特点
-   软件配置对敏捷开发中迭代模式的支撑