添加映射的过程(2) - 解析结点

接着上次的内容,来看看bind中怎么解析<class>

首先,我们来看看Hibernate Mapping DTD 中怎么定义hibernate-mapping与class的关系:

<!ELEMENT hibernate-mapping (meta*, import*, (class|subclass|joined-subclass)*, query*, sql-query*)>


由此,我们可以得出结论:
1、class,subclass,joined-subclass在结构上应该是并列的。
2、subclass与joined-subclass是有关联的。

在mapping包中,我们可以看出这些关联:
1、class,subclass,joined-subclass有共同的基类 - PersistentClass。这是XML的UML建模的规则之一。
2、class对应的mapping类为RootClass
3、subclass,joined-subclass对应的mapping类都是SubClass,通过isJoinedSubclass()方法作为区别。根据“每一棵类继承树对应一个表”的策略,subclass与其根父类应该映射到同一个表;而joined-subclass则是持久化到一个属于它自己的表,即每一个子类对应一个表的映射策略。

好了,有了上面的知识作为铺垫,我们来看看Binder类中的bindRootClass方法。

bindRootClass方法的功能是解析class结点,它的工作其实很简单,就是解析class结点的属性和它下面的所有子结点:

 /**
  * 解析class结点
  
*/

 
public static void bindRootClass(Element node, RootClass model, Mappings mappings) throws MappingException {

  
// 处理公共属性
  bindClass(node, model, mappings);

  
//TABLENAME
  Attribute schemaNode = node.attribute("schema");
  String schema 
= schemaNode==null ? mappings.getSchemaName() : schemaNode.getValue();
  Table table 
= mappings.addTable( schema, getClassTableName(model, node, mappings) );
  model.setTable(table);

  
// 其他属性
  

  
// 处理class下的子结点,做法不好,方法太长太乱。
  Iterator subnodes = node.elementIterator();
  

  
//Primary key constraint
  
// 生成主键
  model.createPrimaryKey();

  
// 处理子结点
  propertiesFromXML(node, model, mappings);

 }

 

整个映射的过程中,都是采用这种自顶向下逐步细化的办法来解析各个结点。在第一遍读源码的过程中,了解到此足矣。

posted on 2005-02-01 14:41  Na57  阅读(656)  评论(0编辑  收藏  举报