麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > DB2 > 正文

DB2 9(Viper)快速入門

2020-01-31 14:52:39
字體:
來源:轉載
供稿:網友
正在看的db2教程是:DB2 9(Viper)快速入門。

為了幫助您快速掌握 DB2 自身的 XML 特性,請完成幾個普通的任務,比如:

  1. 創(chuàng)建用于管理 XML 數據的數據庫對象,包括一個測試數據庫、一些示例表和視圖。
  2. 使用 INSERT 和 IMPORT 語句將 XML 數據填充到數據庫中。
  3. 驗證您的 XML 數據。使用 DB2 開發(fā)和注冊您的 XML 模式,并在導入數據時使用 XMLVALIDATE 選項。
后續(xù)文章將包括其他主題,比如使用 SQL 查詢、更新和刪除 DB2 XML 數據,使用 XQuery 查詢 DB2 XML 數據,開發(fā)存取 DB2 XML 數據的 Java 應用程序和 Web 組件。
創(chuàng)建數據庫對象

讓我們先來創(chuàng)建一個單獨的 DB2 Unicode 數據庫。在 DB2 Viper 中,只有 Unicode 數據庫才能同時存儲 XML 文檔和 SQL 數據的更多傳統(tǒng)格式,比如整數、日期/時間、變長字符串,等等。隨后,您將在這個數據庫中創(chuàng)建對象來管理 XML 和其他類型的數據。

創(chuàng)建測試數據庫

為了創(chuàng)建一個新的 DB2 Unicode “測試” 數據庫,打開 DB2 命令窗口,發(fā)出語句來指定 Unicode 編碼集合和支持的區(qū)域,如 清單 1:

清單 1. 創(chuàng)建用于存儲 XML 數據的數據庫



create database test using codeset UTF-8 territory us



一旦創(chuàng)建了 Unicode 數據庫,您就不需要發(fā)出任何專門的命令或采取任何進一步措施來使 DB2 能夠以它自身分層的格式存儲 XML 數據,因為您的 DB2 系統(tǒng)已經準備好了。

創(chuàng)建示例表

為了存儲 XML 數據,請創(chuàng)建包含一個或多個 XML 列的表。這些表充當文檔集合的邏輯容器;在幕后,DB2 實際上使用了不同的存儲方案來存儲 XML 和非 XML 數據。然而,使用表作為管理各種受支持的數據格式的邏輯對象,簡化了管理和應用程序開發(fā)問題,特別是當需要在一個單獨的查詢中集成不同的數據格式時。

您可以對 DB2 表進行定義,使其只包含 XML 列、只包含傳統(tǒng) SQL 類型的列或者同時包含兩者。本文對后一種情況進行了建模。清單 2 中的例子連接到 “測試” 數據庫,并創(chuàng)建了兩個表。第一個是 “items” 表,追蹤關于貨物的銷售情況和顧客對貨物的評價信息。第二個表追蹤的是關于 “客戶” 的信息,包括關于聯系信息的數據。注意 “comments” 和 “contactinfo” 是基于新的 DB2 XML 數據類型,而所有其他的列都是基于傳統(tǒng) SQL 數據類型的。

清單 2. 創(chuàng)建用于 XML 數據的表



connect to test;

create table items (

id int primary key not null,

brandname varchar(30),

itemname varchar(30),

sku int,

srp decimal(7,2),

comments xml

);

create table clients(

id int primary key not null,

name varchar(50),

status varchar(10),

contactinfo xml

);



如果您仔細地查看這些表定義例子,您將注意到 “comments” 和 “contactinfo” 列都沒有進行 XML 文檔內部結構的定義。這是 DB2 的一個重要特性。用戶不需要為了存儲數據而預定義一個 XML 數據結構(或者,更準確地說是一個 XML 模式)。事實上,DB2 可以在一個單獨的列中存儲任何格式良好的 XML 文檔,這意味著不同模式的 XML 文檔 ―― 或沒有和任何注冊的模式關聯的文檔 ―― 都可以存儲在相同的 DB2 列中。當我們討論如何在 DB2 中存儲數據時,本文將深入討論這個特性。

創(chuàng)建視圖

您可以隨意地在包含 XML 數據的表上創(chuàng)建視圖,就像您可以在只包含傳統(tǒng) SQL 數據類型的表上創(chuàng)建視圖一樣。清單 3 中的例子創(chuàng)建具有 “Gold” 狀態(tài)的客戶的一個視圖:

清單 3. 創(chuàng)建一個包含 XML 數據的視圖



create view goldview as

select id, name, contactinfo

from clients where status='Gold';



關于索引的一點說明

最后,沒有必要在 XML 列上創(chuàng)建專門的索引來提高數據的查詢速度。因為這是一篇介紹性文章,而且示例數據很少,所以本文不會涵蓋到那個主題。然而,在生產環(huán)境中,定義一個適當的索引對實現最佳的性能來說很關鍵。查看本文結尾部分的 “參考資料”,以助于了解 DB2 的新索引技術。

存儲 XML 數據

創(chuàng)建好表之后,現在您就可以用數據填充它們了。您可以通過直接發(fā)出 SQL INSERT 語句來完成這項工作,或者通過調用 DB2 IMPORT 工具在后臺發(fā)出 INSERT 語句。

使用 INSERT 語句

使用 INSERT,您可以直接向 DB2 中填充原始的 XML 數據。如果您已經編寫了一個應用程序并在變量中存儲了 XML 數據,那么這可能是最容易的方法。但是如果您只是剛開始使用 DB2 Viper,并且不想編寫應用程序,那么您可以交互地發(fā)出 INSERT 語句(我發(fā)現使用 DB2 Command Editor 是很方便的,雖然您也可以使用命令行處理器,如果您更喜歡那么做的話)。

要使用 DB2 Command Editor,請啟動 DB2 Control Center。從頂端的下拉菜單 “Tools” 中選擇 Command Editor,將出現一個單獨的窗口,如 圖 1 所示。

圖 1. DB2 Command Editor

DB2 9(Viper)快速入門(圖一)

在上面的窗格中輸入下列語句:

清單 4. 交互地插入 XML 數據



connect to test;

insert into clients values (77, 'John Smith', 'Gold',

xmlparse(document '<addr>111 Main St., Dallas, TX, 00112</addr>'

preserve whitespace)

)



單擊左側的綠色箭頭來執(zhí)行該命令。

注意,聯機提供 XML 數據(如 清單 4 所示)需要您調用 XMLPARSE 函數,以把文檔從字符值轉換成 XML 類型值。本例中的輸入文檔相當簡單 。如果文檔很大或者很復雜,把 XML 數據鍵入到像清單 4 所示的 INSERT 語句中是不切實際的。在大多數情況下,您使用主機變量或者參數標記編寫一個應用程序來插入數據。您將發(fā)現本文帶有一個簡要的 Java 代碼編寫例子。然而,由于這是一個介紹性的教程,所以我們不會詳細地討論應用程序開發(fā)主題。相反,我們將討論使用數據填充 DB2 XML 列的另一種選擇 ―― 使用 IMPORT 工具。

使用 DB2 IMPORT

[1] [2] [3] 下一篇

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 高清国产午夜精品久久久久久 | 黄色一级毛片免费看 | 国产伦精品一区二区三区在线 | 黄色大片在线免费观看 | 欧美成人三级视频 | 亚洲第一页综合 | a网站在线| 免费观看的毛片手机视频 | 欧美大胆xxxx肉体摄影 | 欧美性受xxxx人人本视频 | 精品久久9999| 免费观看黄色一级视频 | 狠狠干最新网址 | 在线观看中文字幕av | 91成人影院 | 欧美一级网 | 成人免费久久网 | 免费国产网站 | 特级黄一级播放 | 免费看搡女人无遮挡的视频 | 91成人免费网站 | 久久久久久久久久久综合 | 久久久久久久一区 | 色猫av | 久久精品亚洲一区 | 精品亚洲午夜久久久久91 | 日日爱影院 | 久草干 | 国产精品1区2区在线观看 | av在线大全 | 国产成年免费视频 | 欧美性受xxxx人人本视频 | 午夜爱爱福利 | 免费a视频| 国产精品99一区二区 | 在线成人毛片 | 91成人在线免费 | 久久精品一区二区三区不卡牛牛 | 中文字幕一二区 | 国产黄色一级大片 | 在线看一级片 |