五月综合缴情婷婷六月,色94色欧美sute亚洲线路二,日韩制服国产精品一区,色噜噜一区二区三区,香港三级午夜理伦三级三

您現(xiàn)在的位置: 365建站網(wǎng) > 365文章 > 深入淺析:用于MySQL的PHP XML類(lèi)

深入淺析:用于MySQL的PHP XML類(lèi)

文章來(lái)源:365jz.com     點(diǎn)擊數(shù):239    更新時(shí)間:2009-12-20 00:35   參與評(píng)論

本文中作者通過(guò)自己創(chuàng)建一個(gè)處理連接MySQL和使用PHP中的domxml功能來(lái)提供XML輸出的類(lèi)。這樣就可以可以在PHP腳本的任何地方聲明這個(gè)類(lèi)并且在需要使用它的時(shí)候可以提供XML功能。

假設(shè)人們使用PHP是原因是他的標(biāo)價(jià):免費(fèi)。MySQL為需要向系統(tǒng)中增加數(shù)據(jù)庫(kù)功能的開(kāi)發(fā)人員提供一個(gè)免費(fèi)的數(shù)據(jù)庫(kù)解決方案。這些解決方案的缺點(diǎn)是在設(shè)置和管理的時(shí)候有些復(fù)雜。

我在這篇文章中使用的PHP版本是PHP 4.3.4 for Win32,可以從The PHP Group下載。MySQL的版本是MySQL 4.0.16 for Win32,可以從MySQL.com得到。MySQL的安裝很容易——只要簡(jiǎn)單地按照其指令來(lái)就可以了。PHP稍微有一點(diǎn)復(fù)雜。

在PHP的下載頁(yè)面有兩個(gè)文件:一個(gè)ZIP文件和一個(gè)安裝文件。因?yàn)槲覀冃枰砑覼IP文件中的擴(kuò)展,所以這兩個(gè)文件都要下載。下面是下載之后的所要做的一個(gè)簡(jiǎn)單步驟:

1. 使用安裝文件安裝PHP;

2. 解壓iconv.dll,將其放到Windows的系統(tǒng)文件夾中;

3. PHP安裝目錄下創(chuàng)建一個(gè)目錄(默認(rèn)為C:\PHP)“extensions”;

4. 解壓PHP_domxml.dll文件到這個(gè)目錄;

5. 在Windows文件夾下找到PHP.ini文件,然后使用記事本或其它文本編輯器打開(kāi)。在這個(gè)文件中找到“extensions_dir=”,然后將其值修改為第3步設(shè)置的擴(kuò)展文件夾的完整路徑;

6. 找到“;extension=PHP_domxml.dll”,刪除本行開(kāi)頭的分號(hào);

7. 重新啟動(dòng)Web服務(wù)器。

然后在你的Web目錄下使用下面的代碼創(chuàng)建一個(gè)PHP頁(yè)面“test.PHP”。(這段代碼在運(yùn)行IIS 5.0的Windows 2000 SP3能夠正常運(yùn)行。)

以下為引用的內(nèi)容:
  run_sql_return_xml("SELECT * FROM users");
     
  classCMySQLXML {

var $host;

var $user;

var $password;

var $db;

functionCMySQLXML($host, $user, $password, $db) {

$this->host = $host;

$this->user = $user;

$this->password = $password;

$this->db = $db;

}

functionrun_sql_return_xml($sql_string) {

$connection = MySQL_connect($this->host, $this->user, $this->password,

$this->db);

MySQL_select_db($this->db);

$result = MySQL_query($sql_string);

$doc = domxml_open_mem("");

while ($row = mysql_fetch_array($result, MySQL_ASSOC)) {

$num_fields = MySQL_num_fields($result);

$row_element = $doc->create_element(MySQL_field_table($result, 0));

$doc_root = $doc->document_element();

$row_element = $doc_root->append_child($row_element);

for ($i = 0; $i < $num_fields; $i++) {

$field_name = MySQL_field_name($result, $i);

$col_element = $doc->create_element($field_name);

$col_element = $row_element->append_child($col_element);

$text_node = $doc->create_text_node($row[$field_name]);

$col_element->append_child($text_node);

}

}

MySQL_free_result($result);

MySQL_close($connection);

return $doc->dump_mem(false);

}

}
 
這個(gè)例子要求你在MySQL上有一個(gè)數(shù)據(jù)庫(kù)“test”,其中有一個(gè)表“users”。而且,你還需要為訪(fǎng)問(wèn)測(cè)試數(shù)據(jù)庫(kù)上的數(shù)據(jù)創(chuàng)建一個(gè)用戶(hù)。創(chuàng)建數(shù)據(jù)庫(kù)、表等的步驟可以查看MySQL的文檔。

如果你分析一下代碼,你就會(huì)明白我創(chuàng)建了一個(gè)叫做CMySqlXML的類(lèi)。CMySqlXML構(gòu)造函數(shù)接受四個(gè)參數(shù):MySQL的主機(jī)名,一個(gè)合法的用戶(hù)名,一個(gè)密碼和一個(gè)數(shù)據(jù)庫(kù)名字。構(gòu)造函數(shù)使用這四個(gè)參數(shù)設(shè)置類(lèi)的host、user、password和db成員變量。

該類(lèi)提供的唯一的一個(gè)方法是run_sql_return_xml()。它接受一個(gè)SQL查詢(xún)字符串參數(shù)。當(dāng)這個(gè)方法執(zhí)行的時(shí)候,它創(chuàng)建一個(gè)到MySQL數(shù)據(jù)庫(kù)的連接并選擇數(shù)據(jù)庫(kù)。查詢(xún)字符串被執(zhí)行,結(jié)果存儲(chǔ)到變量$result中。使用domxml_open_mem()函數(shù)創(chuàng)建一個(gè)新的DOMDocument對(duì)象。然后,代碼開(kāi)始循環(huán)結(jié)果集中的所有記錄。對(duì)于每一條記錄,添加一個(gè)與結(jié)果集的表同名的行元素到DOMDocument文檔元素中。然后為每個(gè)字段添加一個(gè)元素到行元素中,元素名為字段名。最后,一個(gè)文本節(jié)點(diǎn)被添加到每個(gè)字段節(jié)點(diǎn),節(jié)點(diǎn)的值為該字段的值。

在循環(huán)所有行之后,代碼釋放結(jié)果集并關(guān)閉連接。產(chǎn)生的DOMDocument XML從函數(shù)中返回。

在PHP頁(yè)面的開(kāi)始處你會(huì)看到CMySQLXML對(duì)象被實(shí)例化,run_sql_return_xml()方法被調(diào)用。這個(gè)方法的返回值被返回給客戶(hù)。domxml功能除了PHP函數(shù)命名約定之外都遵守DOM規(guī)范。

如果需要更多有關(guān)DOM規(guī)范的信息,可以訪(fǎng)問(wèn)W3C的站點(diǎn)。而更多domxml的信息則可以從The PHP Group找到,在這里你可以下載不同格式的文檔

本文作者:未知

如對(duì)本文有疑問(wèn),請(qǐng)?zhí)峤坏浇涣髡搲?,廣大熱心網(wǎng)友會(huì)為你解答??! 點(diǎn)擊進(jìn)入論壇

發(fā)表評(píng)論 (239人查看,0條評(píng)論)
請(qǐng)自覺(jué)遵守互聯(lián)網(wǎng)相關(guān)的政策法規(guī),嚴(yán)禁發(fā)布色情、暴力、反動(dòng)的言論。
昵稱(chēng):
最新評(píng)論
------分隔線(xiàn)----------------------------

其它欄目

· 建站教程
· 365學(xué)習(xí)

業(yè)務(wù)咨詢(xún)

· 技術(shù)支持
· 服務(wù)時(shí)間:9:00-18:00
365建站網(wǎng)二維碼

Powered by 365建站網(wǎng) RSS地圖 HTML地圖

copyright © 2013-2024 版權(quán)所有 鄂ICP備17013400號(hào)