接着上次的内容,来看看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结点的属性和它下面的所有子结点:
![](/Images/OutliningIndicators/ExpandedBlockStart.gif)
/**//**
* 解析class结点
*/
![](/Images/OutliningIndicators/ExpandedBlockStart.gif)
public static void bindRootClass(Element node, RootClass model, Mappings mappings) throws MappingException
{
![](/Images/OutliningIndicators/InBlock.gif)
// 处理公共属性
bindClass(node, model, mappings);
![](/Images/OutliningIndicators/InBlock.gif)
//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);
![](/Images/OutliningIndicators/InBlock.gif)
// 其他属性
![](/Images/dot.gif)
![](/Images/dot.gif)
![](/Images/OutliningIndicators/InBlock.gif)
// 处理class下的子结点,做法不好,方法太长太乱。
Iterator subnodes = node.elementIterator();
![](/Images/dot.gif)
![](/Images/dot.gif)
![](/Images/OutliningIndicators/InBlock.gif)
//Primary key constraint
// 生成主键
model.createPrimaryKey();
![](/Images/OutliningIndicators/InBlock.gif)
// 处理子结点
propertiesFromXML(node, model, mappings);
![](/Images/OutliningIndicators/InBlock.gif)
}
![](/Images/OutliningIndicators/None.gif)
整个映射的过程中,都是采用这种自顶向下逐步细化的办法来解析各个结点。在第一遍读源码的过程中,了解到此足矣。