MS SQL基础教程:XML文档与数据库表
2007-12-25 15:26:47 来源:WEB开发网 闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閻愵剙鍔ょ紓宥咃躬瀵鎮㈤崗灏栨嫽闁诲酣娼ф竟濠偽i鍓х<闁绘劦鍓欓崝銈囩磽瀹ュ拑韬€殿喖顭烽幃銏ゅ礂鐏忔牗瀚介梺璇查叄濞佳勭珶婵犲伣锝夘敊閸撗咃紲闂佽鍨庨崘锝嗗瘱闂備胶顢婂▍鏇㈠箲閸ヮ剙鐏抽柡鍐ㄧ墕缁€鍐┿亜韫囧海顦﹀ù婊堢畺閺屻劌鈹戦崱娆忓毈缂備降鍔庣划顖炲Φ閸曨垰绠抽悗锝庝簽娴犻箖姊洪棃娑欐悙閻庢矮鍗抽悰顕€宕堕澶嬫櫖濠殿噯绲剧€笛囧箲閸ヮ剙钃熼柣鏂挎憸閻熷綊鏌涢…鎴濇灈妞ゎ剙鐗嗛—鍐Χ鎼粹€茬凹缂備緡鍠楅幐鎼佹偩閻戣棄纭€闁绘劕绉靛Λ鍐春閳ь剚銇勯幒鎴濐伀鐎规挷绀侀埞鎴︽偐閹绘帩浼€缂佹儳褰炵划娆撳蓟濞戞矮娌柟瑙勫姇椤ユ繈姊洪柅鐐茶嫰婢т即鏌熼搹顐e磳闁挎繄鍋涢埞鎴犫偓锝庘偓顓涙櫊閺屽秵娼幏灞藉帯闂佹眹鍊曢幊鎰閹惧瓨濯撮柛鎾村絻閸撳崬顪冮妶鍡楃仸闁荤啿鏅涢悾鐑藉Ψ瑜夐崑鎾绘晲鎼粹剝鐏嶉梺缁樻尰濞叉﹢濡甸崟顖氱疀闂傚牊绋愮花鑲╃磽娴h棄鐓愭慨妯稿妿濡叉劙骞樼拠鑼槰闂佸啿鎼崐濠毸囬弶搴撴斀妞ゆ梻銆嬪銉︺亜椤撶偛妲婚柣锝囧厴楠炴帡骞嬮弮鈧悗濠氭⒑鐟欏嫭鍎楅柛妯衡偓鐔插徍濠电姷鏁告慨鐑藉极閸涘﹥鍙忔い鎾卞灩绾惧鏌熼崜褏甯涢柍閿嬪灦閵囧嫰骞掗崱妞惧缂傚倷绀侀ˇ閬嶅极婵犳氨宓侀柛鈩冪⊕閸婄兘鏌涘┑鍡楊伀妞ゆ梹鍔曢埞鎴︽倻閸モ晝校闂佸憡鎸婚悷锔界┍婵犲洦鍤冮柍鍝勫暟閿涙粓姊鸿ぐ鎺戜喊闁告瑥楠搁埢鎾斥堪閸喓鍘搁柣蹇曞仧绾爼宕戦幘璇茬疀濞达絽鎲¢崐顖炴⒑绾懎浜归悶娑栧劦閸┾偓妞ゆ帒鍟惃娲煛娴e湱澧柍瑙勫灴閹瑩寮堕幋鐘辨闂備礁婀辨灙闁硅姤绮庨崚鎺楀籍閸喎浠虹紓浣割儓椤曟娊鏁冮崒娑氬幈闂佸搫娲㈤崝宀勬倶閻樼粯鐓曢柟鑸妼娴滄儳鈹戦敍鍕杭闁稿﹥鐗犲畷婵嬫晝閳ь剟鈥﹂崸妤€鐒垫い鎺嶈兌缁犲墽鈧厜鍋撳┑鐘辩窔閸嬫鈹戦纭烽練婵炲拑绲垮Σ鎰板箳閹冲磭鍠撻幏鐘绘嚑閼稿灚姣愰梻鍌氬€烽懗鑸电仚濠电偛顕崗妯侯嚕椤愩倖瀚氱€瑰壊鍠栧▓銊︾節閻㈤潧校缁炬澘绉瑰鏌ュ箵閹烘繄鍞甸柣鐘烘鐏忋劌顔忛妷褉鍋撶憴鍕碍婵☆偅绻傞~蹇涙惞閸︻厾锛滃┑鈽嗗灠閹碱偊锝炲鍥╃=濞达綁顥撻崝宥夋煙缁嬪灝鏆遍柣锝囧厴楠炲鏁冮埀顒傜不婵犳碍鍋i柛銉戝啰楠囬悗瑙勬尭缁夋挳鈥旈崘顔嘉ч柛鈩兠棄宥囩磽娴e壊鍎愰柛銊ュ缁顓兼径瀣偓閿嬨亜閹哄秶顦︾€殿喖鐏濋埞鎴﹀煡閸℃浠梺鍛婎焼閸曨収娲告俊銈忕到閸燁垶宕愰崹顐e弿婵☆垳鍘ф禍楣冩倵濮樼偓瀚�

包括SQL Server 7.0 在内的SQL Server 系列版本并不提供XML。 支持开发人员以前不得不使用一个XML 分析器,如微软的XML 分析器(MSXML),而且它们必须编写自己的代码来处理细节:把不同的元素从XML 文档中提取出来并按需要把它们放进关系表的不同部分,然后访问关系表;或者编写代码将数据从数据库表中提取出来,再以正确的格式放回到XML 文档中。当我们在享受XML 所带来的好处时,我们常会发现自己在开发Web 应用程序时不得不应付这样的工作,而且在开发不同的Web 应用程序时仍然不得不重新编写代码。由此可见,开发人员真正需要的是一种在数据库中处理XML 的一般方法而这正是使用SQL Server 2000 时所能作到的,即在关系式数据表中存储XML 文档,从关系式数据中产生XML 文档。
20.3.1 从关系式数据中产生XML 文档
在SQL Server 2000 中通过使用SELECT 语句可以把查询结果存储为XML 文档而不是通常意义上的结果集,这样通过比原来少得多的编码就可以使Web 应用或其它应用直接使用XML 文档,从而方便企业与供应商之间的业务交流。
将关系数据库的查询结果显示成XML 文档是通过FOR XML 语句来完成的。在使用FOR XML 语句的同时可以指定XML 的MODE (RAW、 AUTO、 EXPLICIT)以及XMLDATA 的模式(Schema)。 FOR XML 语句的语法规则为:
FOR XML mode [, XMLDATA] [, ELEMENTS][, BINARY BASE64]
各参数的含义说明如下: mode
表示返回结果集的XML mode, 共有三种取值,即RAW、 AUTO、 EXPLICIT。 XMLDATA
表示将返回XMLDATA 模式。 ELEMENTS
使用该选项时,表示将相应的关系表列作为XML 文档的子元素;否则其将与 XML 属性相匹配。仅当选用AUTO 时才可以使用该选项。 BINARY BASE64
表示由查询返回的二进制数据以64 位编码的形式显示。 1 RAW 模式
使用RAW 模式时查询结果集中的每一行都作为XML 文档的一个元素,非空列将作为相应的XML 文档元素的属性,其属性名与列名保持一致。
2 AUTO 模式
使用AUTO 模式时查询结果集作为嵌套XML 元素。FROM 从句中的每一个表名作为XML 元素,在SELECT 语句中的各列作为XML 文档元素的属性。如果使用ELEMENTS 选项,则SELECT 语句中的各列作为XML 文档元素的子元素。
3 EXPLICIT 模式
在使用EXPLICIT 模式时,查询复写器控制由查询返回的结果集所形成的XML 文档的格式,元素的嵌套层次。以及属性同时必须保证XML 文档是良构(wellformed)的,并且具有有效的XML-DATA 模式。
20.3.2 在关系数据库表中存储XML 文档
在实施B2C (商业到客户)电子商务模式的企业中,客户经常直接在Web 页面订购产品支付现金,这些数据一般并不直接存入数据库中而是基于安全性以及在统一标准下数据转换具有高效性的考虑而将其存储在XML 文档中,然后再存入数据库中。这就需要从XML 文档中提取数据信息并将其存入关系数据库中。在SQL Server 2000 中OPENXML 语句提供了在关系数据库表中存储XML 文档的功能。
OPENXML 是一个行集提供者,与表和视图极为相似。通过OPENXML 提取XML 文档数据与读取关系型行结果集数据一样简单、高效。在使用OPENXML 前必须首先调用sp_xml_preparedocument 系统过程,其主要作用是解析XML 文档,并返回该文档的文件指针。然后该文件指针传给OPENXML, 其根据传来的参数将XML 文档转换成行结果集。最后通过调用sp_xml_removedocument 系统过程来释放由 XML 文档所占用的内存空间。其具体执行过程请参看图20-2。
查看全套"MS SQL入门基础教程"
更多精彩
赞助商链接