电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:7日期:2024-07-07 15:13:24

本文中作者通過(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”。而且,你還需要為訪問(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ī)范的信息,可以訪問(wèn)W3C的站點(diǎn)。而更多domxml的信息則可以從The PHP Group找到,在這里你可以下載不同格式的文檔。

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 青岛代理记账_青岛李沧代理记账公司_青岛崂山代理记账一个月多少钱_青岛德辉财税事务所官网 | 锂电叉车,电动叉车_厂家-山东博峻智能科技有限公司 | 不锈钢闸阀_球阀_蝶阀_止回阀_调节阀_截止阀-可拉伐阀门(上海)有限公司 | 青岛代理记账_青岛李沧代理记账公司_青岛崂山代理记账一个月多少钱_青岛德辉财税事务所官网 | 东莞市踏板石餐饮管理有限公司_正宗桂林米粉_正宗桂林米粉加盟_桂林米粉加盟费-东莞市棒子桂林米粉 | 耐热钢-耐磨钢-山东聚金合金钢铸造有限公司 | 石栏杆_青石栏杆_汉白玉栏杆_花岗岩栏杆 - 【石雕之乡】点石石雕石材厂 | IIS7站长之家-站长工具-爱网站请使用IIS7站长综合查询工具,中国站长【WWW.IIS7.COM】 | 深圳公司注册-工商注册公司-千百顺代理记账公司 | 湖南自考_湖南自学考试网 | 重庆私家花园设计-别墅花园-庭院-景观设计-重庆彩木园林建设有限公司 | 冰雕-冰雪世界-大型冰雕展制作公司-赛北冰雕官网 | 炭黑吸油计_测试仪,单颗粒子硬度仪_ASTM标准炭黑自销-上海贺纳斯仪器仪表有限公司(HITEC中国办事处) | 润滑脂-高温润滑脂-轴承润滑脂-食品级润滑油-索科润滑油脂厂家 | 电销卡_稳定企业大语音卡-归属地可选-世纪通信 | PCB厂|线路板厂|深圳线路板厂|软硬结合板厂|电路板生产厂家|线路板|深圳电路板厂家|铝基板厂家|深联电路-专业生产PCB研发制造 | 北京发电机出租_发电机租赁_北京发电机维修 - 河北腾伦发电机出租 | 礼仪庆典公司,礼仪策划公司,庆典公司,演出公司,演艺公司,年会酒会,生日寿宴,动工仪式,开工仪式,奠基典礼,商务会议,竣工落成,乔迁揭牌,签约启动-东莞市开门红文化传媒有限公司 | 特材真空腔体_哈氏合金/镍基合金/纯镍腔体-无锡国德机械制造有限公司 | 代理记账_免费注册公司_营业执照代办_资质代办-【乐财汇】 | 全温度恒温培养摇床-大容量-立式-远红外二氧化碳培养箱|南荣百科 | 威廉希尔WilliamHill·足球(中国)体育官方网站 | 诺冠气动元件,诺冠电磁阀,海隆防爆阀,norgren气缸-山东锦隆自动化科技有限公司 | 高铝矾土熟料_细粉_骨料_消失模_铸造用铝矾土_铝酸钙粉—嵩峰厂家 | 双段式高压鼓风机-雕刻机用真空泵-绍兴天晨机械有限公司 | 锌合金压铸-铝合金压铸厂-压铸模具-冷挤压-誉格精密压铸 | 消防泵-XBD单级卧式/立式消防泵-上海塑泉泵阀(集团)有限公司 | 大行程影像测量仪-探针型影像测量仪-增强型影像测量仪|首丰百科 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | 真空吸污车_高压清洗车厂家-程力专用汽车股份有限公司官网 | 气密性检测仪_气密性检测设备_防水测试仪_密封测试仪-岳信仪器 | 东莞猎头公司_深圳猎头公司_广州猎头公司-广东万诚猎头提供企业中高端人才招聘服务 | GAST/BRIWATEC/CINCINNATI/KARL-KLEIN/ZIEHL-ABEGG风机|亚喜科技 | 番茄畅听邀请码怎么输入 - Dianw8.com| 苏州防水公司_厂房屋面外墙防水_地下室卫生间防水堵漏-苏州伊诺尔防水工程有限公司 | 消防设施操作员考试报名时间,报名入口,报考条件 | 密封圈_泛塞封_格莱圈-[东莞市国昊密封圈科技有限公司]专注密封圈定制生产厂家 | 顶呱呱交易平台-行业领先的公司资产交易服务平台| Safety light curtain|Belt Sway Switches|Pull Rope Switch|ultrasonic flaw detector-Shandong Zhuoxin Machinery Co., Ltd | 深圳APP开发_手机软件APP定制外包_小程序开发公司-来科信 | 阴离子聚丙烯酰胺价格_PAM_高分子聚丙烯酰胺厂家-河南泰航净水材料有限公司 | 数显恒温油浴-电砂浴-高温油浴振荡器-常州迈科诺仪器有限公司 |