快捷搜索:  as  test  1111  test aNd 8=8  test++aNd+8=8  as++aNd+8=8  as aNd 8=8

怎样下载和记娱乐_集报网



1.概述

我们要将外部系统给的XML文件进行解析,并存入到数据库。

然则我们并没有DTD或者Schema,只有一个WORD款式的阐明文档;更离谱的是,XML结点树的布局(即XML结点与XML结点之间的关系)与营业Bean树的布局(即营业Bean与营业Bean的关系)并不完全同等,比如说,从营业角度讲,一只猪有只猪头,而在XML里,却写成了 pig --content --pighead 的三级关系,无故端多了一个content结点! 没有DTD/Schema,布局又不规范,我们就没法用自动化的第三方JAVA转换API进行解析,而只妙手动地、一个一个地解析。但在手动解析的历程中,我们仍旧发明各个结点的解析和入库中有很多器械是合营的,或者有合营的规律,这些器械可以抽出来作为一个准框架,然后再将结点中不合的部分开放出来,容许详细的结点做详细的实现,并终极形成一个半自动的解析/入库框架。

为什么说它是半自动的?它有哪些限定?

自动:不必为每个结点编写XML 解析代码和入库代码

“半”:需手动地编写每个JAVABEAN,并手动地为每个BEAN建表

限定:

a.所有营业字段的类型只能设为STRING/VARCHAR,并且非营业字段的类型在BEAN中不能为STRING

b.BEAN名与表名必怎样下载和记娱乐须相同,或者可以进行一对一映射

c.BEAN的成员变量名必须与XML结点的属性名/元素名相同,或者可以进行一对一映射

这三种限定都是使用JAVA反射机制进行自动操作的条件。

2.基础思惟

所谓的XML解析,便是将XML结点转换成JAVABEAN实例,XML结点的ATTRIBUTE值和ELEMENT值便是JAVABEAN实例的成员变量值; 所谓的持久化,便是将JAVABEAN实例变成数据库对应表中的一笔记录,JAVABEAN实例的成员变量值便是记录中某个字段的值,或者其他表中某个参考了该记录的另一笔记录。

而在XML中,JAVABEAN体系中,数据据表关系布局中,结点和结点之间的关系都是树形的关系。整体的解析和入库,便是在遍历树时履行转换动作。而我们知道,树的遍历是可以用递归算法实现的,而递归,就不用说了吧,它是实现法度榜样“自动化”的主要道路之一。

以下是对各“树”的详细阐发:

假设两个营业实体A和B之间存在聚合关系(父子关系)。那么详细可分三种环境:

a.B是一个原子字段(即弗成再分),并且是A的一个属性。

XML中,B是A的XML ATTRIBUTE或者A的原子ELEMENT

BEAN中,B是A怎样下载和记娱乐的成员变量,并且B是一个JAVA内置的数据类型

数据库中,B是A表的一个列

b.B是一个复合字段,并且是A的一个属性,而且和A是1:1关系

XML中,B是A的ELEMENT,并且B有自己的ELEMENT或者ATTRIBUTE

BEAN中,B是A的成员变量,并且法度榜样中有个B类

数据库中,B表是A表的子表(即B外键参考了A表)

c.B是一个复合字段,并且是A的一个属性,而且和A是N:1关系

XML中,B是A的ELEMENT,并且B有自己的ELEMENT或者ATTRIBUTE

BEAN中,B组成一个类集(List,Set)配相助为A的成员变量,并且法度榜样中有个B类

数据库中,B表是A表的子表(即B外键参考了A表)

懂得了这三种环境,接下来就好办了。法度榜样每抓到一个结点,都要递归地进行以下处置惩罚:先处置惩罚它的原子属性(情形a),接着处置惩罚它的单个子结点(情形b),着末处置惩罚它的类集子结点( 情形c)。

3.代码实现的重点

两个重点:

a.若何让营业实体在三棵树内逐一对应好?

b.若怎样下载和记娱乐何发明树形关系,比如A的属性有哪些,A的子结点有哪些?

问题a很简单,便是让三棵树里相同的营业实体取相同的名字。

法度榜样在解析时,遍历的是BEAN树;在持久化时也是。比起XML树,BEAN树代表真正的营业布局;比起数据库表关系树,BEAN树才能由父至子地进行先序遍历

4.其他问题

a.要让法度榜样知怎样下载和记娱乐道,原子属性中哪些是XML结点的属性,哪些是XML结点的原子ELEMENT。代码中这是两个抽象措施,必须让详细的结点类实现

b.回首本文概述部分提到的“pig --content --pighead 的三级关系,无故端多了一个content结点”,是以我们要让法度榜样知道,pighead,pigfoot等结点的子结点,究竟是pig,照样pig下的content。处置惩罚不规范XML时要留意这个问题。这也是一个抽象措施,必须让详细的结点类实现

c.与上一条类似但更掉常的,是类集结点的不规范问题。假设一个pig有多个pighead,那布局可能为 pig--pighead,pighead,...,也可能为pig--pigheads--content,content.... 必须让法度榜样知道某个详细结点用的是哪种模式

5.代码

核心:多态 + 递归

a.接口BusiNode

import java.util.*;

import org.dom4j.Element;

/**

* 每个结点都要实现的接口

* 它供给了一些措施以方便实现递归的XML解析和持久化

*

*/

public interface BusiNode {

/**

* 所有类型为弗因素类型的属性

* @return 属性名的聚拢

*/

public List getAtomicPropNames();

/**

* 一些成员变量。这些成员变量是XML结点的属性

* @return

*/

public List getXmlAttributes();

/**

* 一些成员变量。这些成员变量是XML结点的子元素,并且类型为弗因素的

* @return

*/

public List怎样下载和记娱乐 getXmlAtomicElements();

/**

* 所有类型为类集的属性,并且这些类集中每个元素的类型都是BusiNode

* @return key = 属性名, value = 属性类的Class工具。

* 假如为空不返回NULL,而是空的MAP

*/

public Map getCollectionPropsMap();

/**

* 所有类型为BusiNode的属性

* @return 属性名的聚拢

*/

public List getBusiNodePropNames();

/**

* 从XML中解析出来。

* @param element

* @return

*/

public void parseFromXML(Element element);

}

免责声明:以上内容源自网络,版权归原作者所有,如有侵犯您的原创版权请告知,我们将尽快删除相关内容。

您可能还会对下面的文章感兴趣: