- 注册时间
- 2008-9-13
- 最后登录
- 1970-1-1
- 在线时间
- 0 小时
- 阅读权限
- 200
- 积分
- 0
- 帖子
- 24482
- 精华
- 4
- UID
- 9
|
1.0 简介
+ s8 S( ]0 m2 m# n/ y) {2.0 为什么使用数据库?
$ U" f( ?8 Y6 Y" Z3.0 数据和文档的对比 ( I3 I+ p: D0 A6 U W$ h, l7 n
3.1 以数据为主的文件 6 N+ ?* B1 o. X# J# N
3.2 以文档为主的文件 ) {. S$ L- ?1 c5 x- P0 l
3.3 数据(Data)、文件(Documents)和数据库(Databases)
2 |# E) t" S- B4.0 存储和获取数据
; K. z# n: a" K% T 4.1 传输数据 . ?. K0 y) O" B
4.2 将文档结构映射成数据库结构
% m: f, F$ v# A+ U% |. W7 G 4.2.1 以模板驱动的映射 8 e( V4 L+ y! X9 K
4.2.2 以样式驱动的映射 # Q, I2 V1 `1 X6 p2 v: j* S
4.3 数据类型, 空值(Null), 字符集设置和其他所有的类似集
/ ]& ]: H) U& g( z( c) c 4.3.1 数据类型 5 }, i/ |4 q; M
4.3.2 二进制数据
" \% J( N% p) [( I1 i 4.3.3 空值(Null)
3 O( d3 p8 q- \! ? 4.3.4 字符集设置 0 j( e& T/ C7 A/ O
4.3.5 处理指令(Processing Instructions)
* @! s3 X5 q$ V' Q7 ]9 f! V 4.3.6 存储(Storing Markup) % k3 w3 A3 I' p
4.4 从数据库的结构生成DTDs和逆反过程 ; m1 W2 F* X W Y
5.0 存储和获取文件(Documents)
# V/ o) W1 m$ l( f" D4 c+ f% P/ E* g 5.1 管理内容系统和关系数据库
0 |! _! U0 |: S6.0 可利用的软件
2 N# l n6 W& q0 C. Y 6.1 中间件
* ], |) _! D6 d7 f( n0 A 6.2 XML服务器 ! S7 ], l0 }4 G! i% a
6.3 内容管理系统(Content Management Systems) , X5 F, `6 I3 j4 [: F
7.0 附加联接 6 f9 t8 y9 I" N& m% J
8.0 注释和反馈
( U- n: N2 N3 C, J-----------------------------------------------------------------------
, G/ b$ m& R7 c$ B; x& }1.0 简介 * K7 O% z: ~8 L- j" A7 F
本论文简要的探讨了XML和数据库之间的关系,同时罗列出一些可以使用数据库处理XML文档的软件工具。虽然在这里不可能详尽地介绍和提供对这些软件更深层次的评价,但是我希望它能够描述使用数据库处理XML文档中的主要部分。这里有点偏向与关系数据库,因为我的经验如此。 , B0 g! W8 i, ]/ p3 _
: c! T! f0 F6 w4 p$ s% M# F2.0 为什么使用数据库? 2 F! g& z( \- [. u
当你考虑到要使用XML和数据库时的第一个要问你自己的问题应该是:为什么我需要使用数据库。你是需要显示数据?你是需要一个保存你主页的空间?数据库在电子商务运用程序中时把XML当做数据传输格式传送吗?这些问题的答案都将直接影响到你对数据库和中间件(如果使用了的话)的选择。 举例说明,假设你是把XML做为一种数据传输
+ _, B% n/ e( P. ^1 u( u" [格式使用在你的电子商务运用程序中。
* M1 }" @( N/ |2 h那么意味着你需要传输的数据格式将主要是具有高度规范结构,那么在XML中的那些自己的编码规范对你而言并不重要了,这样你的兴趣就仅仅是在数据上而不是在这些数据如何物理存储在文 档中了。如果你的运用程序关系简单,那么一个关系数据库和数据传输中间件将能够满足你的需求;如果关系庞大和复杂,那么你就需要一个完全支持XML的开发环境了。
0 g, W# w6 U) l* V 从另一方面来说,假设你是要实现从杂散的XML文件中创建一个网站的功能。你不仅需要管理这个网站,你还要提供给用户查询其中内容的功能。这时你的文件的格式将是高度
; ?, Q: s% h1 _4 g* r5 ^* \的不规范,而实体的使用对你来说变得很重要,因为这些文件的结构是网站的基本功能需求。
6 d; X/ W8 `6 ^- {6 D% O! n" b' b在这个例子中,你就需要一些"native XML"数据库而不是普通的关系数据库,执行解释
5 d' c# c6 \9 z, |5 r- m+ V、XML实体使用和支持查询语言(例如XQL)。
) I; g0 _8 Y4 b" h& p; S; z: H) L* M8 Y0 b% a* S
$ o* O& O" e8 L# C0 \: a3.0 数据和文档的对比
: X& _" x. f. |0 @; l 也许在大多数情况下,判断是否采用数据库的最重要的因素是你使用数据库是用来 ; d8 x, j r! } A
保存数据呢还是保存文件。如果你想保存数据, 你需要的数据库则主要是面向数据存储的,例如一
/ g* Y6 b' \4 T) Y8 }个关系数据库或则一个面向对象的数据库,或则也可以是一个在数据库和XML文档之间传递数据的 , n$ S, K `. Z5 A7 ]* t* a
中间件。从另一个角度来说,如果你想存储文件,你需要一个专门设计用来存储文件的内容管理
3 @! Q/ |! ?, M w, H: K系统。虽然可以把文件保存在关系数据库或则面向对象的数据库中,但你会发现你的工作
) O( t/ I4 r( H/ K" D' _ ]$ C经常是在重复实现一个内容管理系统中的功能而已。简单说,虽然一个内容管理系统通常是建立
8 O( @! V7 F) {3 v Q在一个面向对象数据库或则关系数据库的顶层,但是如果只是把一个内容管理系统当做数据库
( f. Q/ _! i* y1 |& ^来使用被证明是失败的。 * n% k; o5 |9 {# H1 |
你是否需要存储数据或则文件经常取决与你的XML文件。原因是XML文件分为两类: $ A5 d! D8 @9 Q8 Y4 t- C2 s! B
数据为主和文档为主。
! V) ?9 f$ }; z8 c9 S5 P
. C6 d+ d4 K. N- f- ~4 [- K* w$ Y7 N3.1 数据为主的文件
/ p x* H6 k# r9 d" K8 T 数据为主的文件表现出来的特点是结构相当规范,数据格式良好(就是说,数据中 - l. k$ ]4 b' d3 m7 n& i$ U
最小的独立单元是PCDATA-only元素级别或则是一个属性),和一些或则没有混合内容。其中同 / E1 t8 n5 j" Y( Q+ a. U! {+ z( ^9 ^
类型元素和PCDATA的出现顺序并不重要。例如XML文件内容是销售单、飞行计划、餐馆菜单等等。
U/ G! M: i! N数据为主的文件经常被用来设计机器消费,这时XML的调用是多余的---它仅仅是一种数 ) I) f; U9 o/ z( k- L8 Z" f' v* B
据传输。 # Z2 j! l- A& w% ]: ~6 I. ?8 i4 O4 V
例如,下面的销售单就是一个数据为主的文档: / e& O- F1 u/ K7 S! o" q
<Orders>
$ L) ^7 z$ P/ p& h3 ^, }& y4 ~; a <SalesOrder SONumber="12345">
( l1 K* s- }6 K1 p, [/ l2 {% s7 q4 [' A <Customer CustNumber="543">
4 A, z9 R2 b! @6 t9 \+ @ <CustName>ABC Industries</CustName>
/ Z' [9 P/ w0 {8 e <Street>123 Main St.</Street>
, ^' G0 B4 F& e1 Z <City>Chicago</City>
% f, D% y/ V0 n3 x/ [# H <State>IL</State>
% i" \" U: j8 T: B/ @7 r) x <PostCode>60609</PostCode>
, D- D" u% V# U4 r$ E. v, g </Customer>
- J* R9 N( ?$ Z: F9 x4 W6 U) h <OrderDate>981215</OrderDate>
# g- g7 ?0 t C$ _/ K <Line LineNumber="1">
. ]0 B+ ^ ~; I+ c& Y) O ` <Part PartNumber="123">
$ Z% d& f3 b& u+ x <Description>
- x4 g, j& d. T# f <p>Turkey wrench:<br />
8 I3 C2 z; N. x- H9 t* n$ k Stainless steel, one-piece construction,
2 V9 S2 X5 o M( I. Z lifetime guarantee.</p>
) f) W* @" u; h& M w) h </Description> 7 X$ V6 [) A/ f: n2 o( u) Z- A; t$ h
<Price>9.95</Price> 5 F* ?/ z; b8 g' f, f/ c0 n# x* s
</Part>
) {) M5 M& U& P, I <Quantity>10</Quantity> 9 {! b* \7 h( P5 s
</Line>
3 p7 _# e/ w5 V <Line LineNumber="2">
: d$ m! X& p' w3 A3 S6 F" x <Part PartNumber="456"> : H4 \9 Q$ k4 g h
<Description>
& U* b1 z) @# j" V <p>Stuffing separator:<br />
. z7 }: m& d' Q [9 ]( k Aluminum, one-year guarantee.</p> # N: I; a) h4 Z1 i* W
</Description> , x+ h' t1 O" }' f0 \
<Price>13.27</Price>
' _! e& Z H9 f5 M' c </Part> 4 ]2 R- l1 z5 ~: I v2 h
<Quantity>5</Quantity> : R. K0 I5 g/ A! \8 e+ W
</Line>
. ~# V# f# e! f6 w4 U </SalesOrder> ! R2 K, l/ c# m s
</Orders> , i; X) x+ T! r5 C
注意在XML世界中,许多(其实应该是大量)的文件实际上都是数据为主的。例如,
% a3 u* v" J! ^4 @( d9 N5 t& e考虑在Amazon.com网站上显示一本书的各种信息的页面,虽然这个页面是一个相当巨大的文 9 }% c% o$ I! r4 r, D0 j$ R' J
本,但是这个文本的结构是高度规范的,所有页面都包含有介绍书的共同点,并且每一页中文本
+ C* w6 y5 {7 F: o% ?1 f, K的大小是受限制的。也就是说,它可以从一个简单的、数据为主的XML文档 + 包含有每一页信息 ! L; Y1 Y/ H% n2 W
的数据库+ XSL样板文件 就能够实现这个网站的结构了。通常,目前任何一个动态建立HTML的网 / L& U2 Z$ ~+ |4 L" m* M1 \8 J+ ^
站都可以被上面介绍的这种结构来实现的。 : z" a2 n! R3 A2 m
下面是一个很简单的例子: 4 X4 e! a( G$ {1 G. g5 N
<Lease> 5 R: ^$ [) p: q
<Lessee>ABC Industries</Lessee> agrees to lease the property at
4 u* E+ R q& c6 X1 y$ g& m2 [( H <Address>123 Main St., Chicago, IL</Address> from <Lessor>XYZ
" M' O- x$ A" [5 S8 p Properties</Lessor> for a term of not less than <LeaseTerm x0 n6 d- [& K9 m
TimeUnit="Months">18</LeaseTerm> at a cost of <Price / F6 o0 @$ M6 Z
Currency="USD" TimeUnit="Months">1000</Price>.
5 c, S, s- E7 }3 B) W9 [ </Lease> 1 \7 N) A4 ~6 t) U$ Z a d, _
它是使用下面的这个XML文档和一个简单的样板文件实现的: 9 v4 `' I" O; ^. y; ?
<Lease> ) j! R# G9 B9 A0 `
<Lessee>ABC Industries</Lessee> 2 Z0 n3 q5 ~& u" k
<Address>123 Main St., Chicago, IL</Address>
5 }/ ?; `8 Q# Z" }1 L1 j <Lessor>XYZ Properties</Lessor>
" r x- I5 N5 {5 n1 r5 o <LeaseTerm TimeUnit="Months">18</LeaseTerm>
* x. g. j% t5 k <Price Currency="USD" TimeUnit="Months">1000</Price>
! X6 b7 ~/ y( X: D; { </Lease>
* G6 @9 r: _. U0 C2 W+ ^- l8 h/ b# a' J: D
3.2 以文档为主的文件 3 k7 C. Z2 F9 o: Y
以文档为主的文件表现出来的特点是:不规范的结构,大量的原始数据(就是说,
. p t8 R) m R* U- N最小的独立数据单元是包含有混合内容的元素级或则本身就是一个文档),和大量混合内容。其中
3 F3 i" ~8 U. J- W; v. g同类型元素和PCDATA出现顺序是非常重要的。例如一本书,一封电子邮件,广告,以及几乎所有的 ( m3 |9 h5 ^. F& Y
XHTML文档。以文档为主的文件通常是用来设计人文消费: 5 n% b( Z! v" f- G5 {* k
例如,下面的产品描述就是一个以文档为主的文件: 8 v% l& Q6 d" U3 ^" S2 E
<Product> 7 D5 s0 N- S. V, R4 s
<Name>Turkey Wrench</Name>
2 D9 z" ^# P2 b# c <Developer>Full Fabrication Labs, Inc.</Developer>
5 X" ?% A6 w# {- B <Summary>Like a monkey wrench, but not as big.</Summary>
( h1 ]7 X5 S6 I* c6 C B <Description>
5 y& W3 W) ~, w# X1 F <Para>The turkey wrench, which comes in both right- and . |/ X, V$ I: x: D
left-handed versions (skyhook optional), is made of the finest
+ y; z8 c' `/ k/ m: | stainless steel. The Readi-grip rubberized handle quickly adapts
+ ^) c: B; c# k9 G3 [6 h, d0 g to your hands, even in the greasiest situations. Adjustment is " ?0 G2 }; R$ e$ h+ p
possible through a variety of custom dials.</Para> 9 \& }/ \! M0 n# q) w
<Para>You can:</Para>
+ d4 v4 [5 g, }* u; K <List>
3 Z9 d3 L& ` i9 P <Item><Link URL="Order.html">Order your own turkey wrench</Link></Item>
2 q! z5 c7 {8 U' V6 A <Item><Link URL="Wrenches.htm">Read more about wrenches</Link></Item>
5 u4 F/ t* a( z" l4 U <Item><Link URL="catalog.zip">Download the catalog</Link></Item> 3 n* @+ N( Z$ m; u! r' p2 X
</List> ! m) I( O+ I8 d z
<Para>The turkey wrench costs just $19.99 and, if you ' I6 e) m; x/ R& t j
order now, comes with a hand-crafted shrimp hammer as a 1 n$ g! ?9 X3 K6 q& s' a0 W
bonus gift.</Para> - e& i$ \9 T; d
</Description> 8 C3 r7 E& M% F4 [( [/ k
% x5 ^& ^% j( T# s" D
3.3 数据(Data)、文件(Documents)和数据库(Databases) * z5 a6 L3 @2 S& Q- U
事实上,数据为主的文件和文档为主的文见之间的区别并不是很清晰。例如,虽然
g5 o. e- B6 Z; d2 Q8 ~7 p2 \一个数据为主的文件(例如一张发票),也有可能包含大量的不规范结构的数据,例如发票的描
! `4 i1 [4 J- A# d; K4 W" ^述部分。而一个以文档为主的文件(例如用户手册),也可能包含有规范的数据结构(通常是元数 ! W& D# V) ^- q- S7 y2 Q
据metadata),例如作者名和再版日期。除了这些,你用来判断是否是两者中其一的另外
# c! j3 t5 O) i7 Q( I' l9 M( W一个重要特点是你是对数据还是对文档感兴趣,这也将决定你要采用什么样的系统。 - s/ b: A9 Z1 L& b
要存储和获取数据,你可以使用一个数据库(通常是关系数据库,面向对象数据库 8 c/ e8 j) }( p8 Q6 i
或则树状体系数据库)和中间件,或则你也可以使用XML服务器(你可以把它看成是将数据库
! h- |# d8 k' v# }和中间件捆绑在一起)。要保存文档,你将需要一个内容管理系统。有关各种系统的探讨 / |3 ?8 @+ {( @
在第4.0小节中, "存储和获取数据"和第5.0小节 "存储和获取文档".你能够在第6.0小节找到
! {! p7 \- L$ ~, m- U$ k一些可使用的软件列表"可利用的软件"。
' h9 D- F2 i% n
7 U: `! v/ S! X0 T4.0 存储和获取数据 . Y: |/ l. ^( c& ~5 ?
数据的类型可以在数据为主的文件的原始定义或则从数据库中的字段类型中得到。 - f& `+ ~" ^. [+ @2 K
前者的例子是你想把数据库中的数据保存成XML文件放到网站上;后者的例子是你需
) Z5 E( q( O9 y6 s要把大量的数据保存到关系数据库中。根据你的具体需求,你需要的软件或则是把XML数据
# Z' A! [2 a/ K4 N% F读入到数据库或则是把数据库中的数据输出到XML文件,或则两者都支持。 5 D8 x/ }5 `6 h9 |7 H5 u6 a
C/ e6 M* b' h. M4.1 转录数据
: e0 A- q' t0 J7 }# p1 k1 p 当将数据保存在数据库中,它经常需要抛弃与文档信息有关的大量内容,例如它的
4 ~4 k [ l' L, I名称和DTD,同时还有它的物理结构,例如实体的定义和使用、属性值和相同类型元素的出现顺 Q) B! D# i* P* [. @& m
序,还有二进制数据的存储方式 (是经过Base64编码的还是没有经过编码的实体或则其他方式),
N- `4 t3 W4 I. \3 `8 i/ w, SCDATA的内容和其他编码信息。简单而言,当从数据库中获取信息时,最后生成的XML文档结果可 & T* A' A7 K8 i
能不包含任何CDATA或则实体运用(entity usage) (除非预先定义了实体lt(就是符号"<"
1 p% f6 j2 G( n),gt(">", amp("&", apos("'", quot(""")和同类型元素、属性出现的顺序。 ) ]1 _+ x" j" p5 w0 O. g; Y
例如,假设你需要把一个销售单的信息使用XML格式从一个数据库中获取数据然后转
' W' d" r' @+ {" H" _* ]录到另外一个数据库中,在这个例子中,在XML文档中并不关心销售单的编号是保存在销售单的日 ) r; V$ U7 Z6 E
期的前面还是后面,也不用关心是否将顾客的名称保存在CDATA section作为一个扩展入口,
- k- Y8 E# {- x; y4 U9 H或则甚至直接当成一个PCDATA. 但是,对于将这些相关数据从第一个数据库中转录到第二个数据 ! S" P- F& J1 a+ M$ B
库的过程中,这些信息都是非常重要的。这样,这个数据传输软件就需要考虑使用树状结构
' ~8 ~: e9 }0 u& v% P7 q- q7 t5 G j# V(它将一个单独的销售单的信息用组(group)来实现)。
: _, y1 G8 u+ L( H 另一个当忽略文档信息和它的物理结构会带来麻烦的例子是---"借贷套利"文档,它 9 t( d3 K- S3 U; P. h
保存的数据是从一个数据库中的文档中获取,并且需要重新组装这些数据成为一个新的文档, 6 W3 f8 ~# F& X v% q! A
而这个过程经常会导致新的文档的结构和原来的文档会不一致。
4 [9 l B( C: c+ `6 T+ a( d& d 从上面的例子可以看出,对于数据库和数据传输中间件的选择是根据你的需求而变
7 O( q, D' m9 y3 ?$ g化的。 |
|