用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<String, String> configMap = new HashMap<String, String>();  //与技能组相关的配置,用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<String, String> getConfigMap() {
  return configMap;
  }
  public void setConfigMap(Map<String, String> configMap) {
  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<TskillGroup> l = skillGroupDao.find(hql, params);
  循环list得到TskillGroup对象tsg
  查出tsg对象对应的配置属性:tsg.getConfigMap().get(配置属性的key)