当前位置:七道奇文章资讯编程技术Java编程
日期:2011-03-22 16:16:00  来源:本站整理

将XML结点转换成JAVABEAN并存入数据库[Java编程]

赞助商链接



  本文“将XML结点转换成JAVABEAN并存入数据库[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

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).
  以上是“将XML结点转换成JAVABEAN并存入数据库[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:

  • 将XML结点转换成JAVABEAN并存入数据库
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .