目前项目中遇到一个问题。数据字典以后会有些变动,扩展一些字段,这些字段要保存在配置文件中,数据库最好不要做改动。这样做的目的是方便以后灵活扩展,只需要改配置文件。
现在有一个解决方案是将现有的数据字段正常设计到数据表。每张表都有一个扩展字段,用来存储其它扩展数据,格式为text。其中的数据以xml数据格式存储,以区分字段信息。
实体bean的设计是这样设计的:每个表对应一个Basicbean,不包括数据表中的扩展字段。每个bean扩展一个子类dynamicBean,用list保存表中扩展字段中的xml数据解析出来的对象。
为了xml中的数据可以解析成为对象,项目中用到了
XStream,这是一个可以将对象序列化成xml数据,并且可以把xml数据解析成为对象的一个开源框架,非常简单,两分钟就可以轻松使用。
为了使由Xstream序列化成的xml数据有良好的可读性,需要设计一个类来封装扩展字段。如:User的扩展字段封装成UserItem(name,value)。
这样如果以后User需要扩展字段age,就可以新增一个UserItem(age,22)。添加到UserDynamicBean中的list中。由Xstream序列化成xml数据,同其它现有的字段一同存入数据库。从数据库中读取数据时也是一样:把除扩展字段以外的字段映射到BasicBean。读取扩展字段中的xml数据,用Xstream解析出保存有Item对象的list。然后把BasicBean与list封装到dynamicBean,提供给上层使用。
这是一个初步的解决思路,哪位有比较好的解决办法请不吝赐教。