前一段时间一直是使用同事写的fmpp 解析csv文件生成 Spring+Hibernate+Struts+vm(velocity模版)代码,每次针对一个表配置一个csv,还要好好思索意义各个表之间的对应关系,既不容易配置csv也容易出错。趁这个清明节三天假期没事情作就着手写一个fmpp解析PDM的程序目前还在完善阶段,Hibernate方面已经基本写完,找很少可以时间经常使用的映射关系,而且此次将复合主键也包括在内,对于没有指主键的table默认将第一个字段设置为主键(相信你们在设计表的时候都习惯将主键设置为第一个字段),闲话很少说了,说一下里面的关键点:
XML 命名空间
将默认状况下,当你写的东西像doc.book ,而后将选择的元素名称的图书,不属于任何XML命名空间(相似的XPath ) 。若是您想选择一个因素,是在一个XML命名空间,您必须注册一个前缀和使用。例如,若是内容本书是在XML命名空间http://example.com/ebook ,那么你必须定义前缀在模版上方
<#ftl ns_prefixes={"e":"http://example.com/ebook"}>
如今你能够写表达式 doc["e:book"]. (使用方括号语法要求,不然会混淆FreeMarker.)
而在PDM中使用了XML 命名空间因此应当先定义XML 命名空间(ns_prefixes)
<#ftl ns_prefixes={"a":"attribute","c":"collection","o":"object"}>
不少人将a: c: o: 改成a_ c_ o_ 这也是一种方法,可是如此以来你每次更改PDM设计的时候都要从新修改
2.属性: 使用@符号
3.搜索PDM内指定Id的元素:
table["//o:Column[@Id='${pcl.@Ref}']"] 上面一段话的关键是 // 他的意思时 从table下查找Id为${pcl.@Ref}的字段 好了上面就是最关键的地方,若是管住的人多,我会考虑在完成后继续讲解