论坛首页 Java企业应用论坛

关于数据的可扩展性问题

浏览 3615 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2007-09-30  
      目前项目中遇到一个问题。数据字典以后会有些变动,扩展一些字段,这些字段要保存在配置文件中,数据库最好不要做改动。这样做的目的是方便以后灵活扩展,只需要改配置文件。
      现在有一个解决方案是将现有的数据字段正常设计到数据表。每张表都有一个扩展字段,用来存储其它扩展数据,格式为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,提供给上层使用。
     这是一个初步的解决思路,哪位有比较好的解决办法请不吝赐教。
   发表时间:2007-10-02  
有一个疑问
假如我想查询你的扩展字段的内容,你就不能提供以sql的检索方法了,相对的,检索速度也就无法考虑了
0 请登录后投票
   发表时间:2007-10-04  
是这样的,扩展字段的信息都是不需要查询的,做为以有字段的补充信息。
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics