新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> Oracle, SQL Server与XML,XML在数据挖掘中的应用, PMML.
    [返回] 中文XML论坛 - 专业的XML技术讨论区XML.ORG.CN讨论区 - 高级XML应用『 XML 与 数据库 』 → 使用XML合并多种数据系统[转帖] 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 7964 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 使用XML合并多种数据系统[转帖] 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     diegor 帅哥哟,离线,有人找我吗?白羊座1979-4-10
      
      
      威望:4
      等级:大二(研究C++)|大二(研究汇编)
      文章:266
      积分:806
      门派:XML.ORG.CN
      注册:2004/3/3

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给diegor发送一个短消息 把diegor加入好友 查看diegor的个人资料 搜索diegor在『 XML 与 数据库 』的所有贴子 引用回复这个贴子 回复这个贴子 查看diegor的博客楼主
    发贴心情 使用XML合并多种数据系统[转帖]

    XML最酷的一点就是它的平台无关的表现数据的方法。更加优美的是如果你需要将两个或者更多数据源合并到一个逻辑数据源,使用XML可以轻松地做到这一点。

    我频繁遇到的一个例子是合并DB2数据源和Microsoft SQL数据源。你的新应用程序要收集数据并将其存储到SQL 2000中。然而,任何用户相关的数据(比如说人力资源数据)都存储在DB2中。如果你需要从两个数据源收集数据就会出现问题。但是,使用XML,所有你要做的就是为两个数据源创建相同的XML结构然后将它们合并。如果你正在通过一个XSLT转换操作这些信息,这种做法就会相当地有用。
    例如,假设你正在收集的用户信息由于在其它数据库中会发生改变而因此不能存储到其它的数据库中。但是因为你需要访问它,从而为你在应用程序中收集的信息提供一个报表,而且必须保持最新。这可能是用户的地址,存储在DB2数据库中。而在应用程序中收集的信息存储在SQL 2000数据库中。你需要从两个数据源收集信息并把它们合并起来以创建报表。
    在单个数据库中,你一般会通过唯一标识符来关联信息。你可以使用这个唯一标识符来查询另一个数据库中的信息。所以不需要在另外一个数据库中再存储一次地址信息,你可以将唯一标识符保持在你的辅助数据库而使用它从主数据库中取得信息。
    唯一标识符可能是一个员工ID。你知道使用员工ID可以从DB2数据库中取得正确的地址,所以你所要做的就只是在SQL 2000数据库中存储员工的ID。稍微计划一下,你可以创建一个合并数据并转成最终报表的系统。
    下面我们假设有一个DB2表LOCATIONS存储员工的工作地址。这个地址信息与EMPLOYEES表(此表存储员工的关键信息)中的LOCATION_ID相关。在我们的SQL 2000数据库中,我们收集用户喜欢的颜色并存储在表FAV_COLOR中。FAV_COLOR表有三个字段:name、emp_id和fav_color(我们假设存储名字是安全的,也就是说假设没有人重名)。要访问这些不同的数据库服务器,我们有两个对象叫做DB2和SQL。除了连接不同之外每个对象有相同的类型。这些对象的类包含两个方法:RunSPReturnXML和RunSQLReturnXML。第一个方法运行一个存储过程然后返回XML数据;第二个方法运行一个SQL查询字符串然后、返回XML数据。
    为了避免为这个方法使用特定的脚本技术,我使用伪代码编写这个类。
    Class Data

    Method RunSPReturnXML(stored_procedure, params)
        Send stored_procedure to database with params.
        If database doesn't support XML output, take recordset and
            convert it to XML.
        Return XML.
    End Method

    Method RunSQLReturnXML(sql, params)
        Send sql to database with params.
        If database doesn't support XML output, take recordset and
            convert it to XML.
        Return XML.
    End Method

    Class_Initialize
        Instantiate needed objects such as database connection tools.
        Connect to database.
    End Class_Initialize

    Class_Terminate
        Disconnect from database.
        Clean up instantiated objects and end.
    End Class_Terminate

    End Class
    为了使用这个类为报表合并数据,我们将通过把员工ID传递给DB2和SQL 2000来为每个员工提供一个报表(这次我依然使用伪代码):

    SQL = new Data
    DB2 = new Data
    DOMSQL = new DOMDocument
    DOMDB2 = new DOMDocument
    employee_id = 999999

    DOMSQL.loadXML(SQL.RunSPReturnXML("get_fav_color", (employee_id)))
    DOMDB2.loadXML(DB2.RunSQLReturnXML("SELECT LOCATIONS.ADDRESS1,
    LOCATIONS.ADDRESS2, LOCATIONS.CITY, LOCATIONS.STATE, LOCATIONS.ZIP FROM
    EMPLOYEES INNER JOIN LOCATIONS ON EMPLOYEES.LOCATION_ID = LOCATIONS.LOCATION_ID
    WHERE EMPLOYEES.EMP_ID = ?", (employee_id)))
    我们假设从SQL得到的XML的格式如下:
    <FAV_COLOR>
        <name>John Q. Public</name>
        <emp_id>999999</emp_id>
        <fav_color>blue</fav_color>
    </FAV_COLOR>
    我们还假设DB2 XML数据的格式如下:
    <LOCATION>
        <ADDRESS1>. . .</ADDRESS1>
        <ADDRESS2>. . .</ADDRESS2>
        <CITY>. . .</CITY>
        <STATE>. . .</STATE>
        <ZIP>. . .</ZIP>
    </LOCATION>
    然后可以使用下面的代码合并这两个XML:
    DOMSQL.appendChild(DOMDB2.selectSingleNode("//LOCATION"))
    得出的最终结构如下:
    <FAV_COLOR>
        <name/>
        <emp_id/>
        <fav_color/>
        <LOCATION>
            <ADDRESS1/>
            <ADDRESS2/>
            <CITY/>
            <STATE/>
            <ZIP/>
        </LOCATION>
    </FAV_COLOR>
    完整的DOMDocument可以通过一个XSLT转换来运行。使用这个解决方案可以合并数据从而得到你真正需要的结果。而且,你还会发现使用DOM方法操纵数据很容易。这么简单地合并不同系统的数据都是DOM方法的功劳。

    (转自:ZDNET)


       收藏   分享  
    顶(0)
      




    ----------------------------------------------
    坚决支持XML!

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/3/11 15:58:00
     
     GoogleAdSense白羊座1979-4-10
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 XML 与 数据库 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/10/31 23:02:44

    本主题贴数1,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    62.500ms