亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > PHP > 正文

Creole :新興數據抽象層

2019-09-08 23:11:39
字體:
來源:轉載
供稿:網友
說起數據抽象層,大家可能首先想起的就是ADODB。這里要為大家介紹的是一個全新的數據抽象層:Creole。說它新,是因為它是用PHP5寫的,是一個基于真正意義的OO的層;它的API接口以JDBC為基礎,熟悉JDBC的朋友用起來應該會很親切;它現在支持的數據庫有MySQL, MS SQL Server, PostgreSQL, SQLite。Oracle的driver正在開發中,當然,你也可以為自己要使用的數據庫寫Driver。


安裝
下面我們就來看看在Windows+Apache+PHP5上Creole的安裝和初步使用。首先你要安裝好PEAR,如果你還沒有安裝好,可以雙擊php目錄下的go-pear.bat文件,然后這個程序會引導你進行安裝。關于PEAR的安裝不是本文的內容,請自行查閱相關資料。當你安裝好PEAR后,我們就要利用它的install功能了。
首先進入命令行方式,Cd到你安裝php的目錄下。然后在命令行中鍵入下邊命令,這樣PEAR會自動幫我們下載并安裝好Creole包。

pear install http://creole.phpdb.org/pear/creole-current.tgz



如果你鍵入的命令正確的話,應該看到下邊的安裝提示。

500) this.width=500" vspace=10 border=0>


這樣我們就已經成功安裝好了Creole,不過為了能使用它我們還得再安裝一個jargon包,這個包封裝了數據表和字段層次的一些信息。安裝的方法和上邊一樣,鍵入如下命令就可以了:

pear install http://creole.phpdb.org/pear/jargon-current.tgz



配置
下面我們就可以使用Creole了。在web可以訪問的目錄下建立一個PHP文件,我們先來嘗試包含Creole類,這是每一個要使用Creole的程序都要做的事。我們加入下邊的代碼:

require_once 'creole/Creole.php';



然后在瀏覽器中訪問這個頁面,結果出現了下邊的錯誤:


Warning: main(/creole/Creole.php) [function.main]: failed to open stream: No such file or directory in c:/program files/EasyPHP5/home/dev/test.php on line 2

Fatal error: main() [function.require]: Failed opening required '/creole/Creole.php' (include_path='.;C:/php5/pear') in c:/program files/EasyPHP5/home/dev/test.php on line 2


這是因為我們沒有設置好php.ini來包含PEAR庫的路徑,所以php.exe找不到文件,只好報錯了。現在我們把PEAR庫的地址添加到php.ini中。在php.ini中找到這段:


;;;;;;;;;;;;;;;;;;;;;;;;;
; Paths and Directories ;
;;;;;;;;;;;;;;;;;;;;;;;;;

; UNIX: "/path1:/path2"
;include_path = ".:/php/includes"
;
; Windows: "path1;path2"
;include_path = ".;c:/php/includes"


將最后一行改成:

include_path = ".;C:/Program Files/EasyPHP5/php/PEAR"


其中C:/Program Files/EasyPHP5/php/PEAR是PEAR在你機器上的絕對路徑。注意要去掉行首的分號。然后重啟Apache。再訪問看看,好了。:)



試用
現在開始我們就可以在程序中使用Creole了。下邊我們將連接數據庫,并從中取出user表的全部用戶。下邊是完整的代碼:


<?php
require_once 'creole/Creole.php';
$dsn = "mysql://root@localhost/r4";
$conn = Creole::getConnection($dsn);
$rs = $conn->executeQuery("SELECT * FROM user");
while($rs->next())
{
echo $rs->getString("login_name") . " (" . $rs->getInt("id") . ")";
}
?>


這里講解下上邊代碼的含義。第一行載入了Creole類,第二行定義了一個用于連接數據庫的字符串,格式是“數據庫類型名://用戶名:密碼@HOST/數據庫名”。第三行創建了一個連接對象,第四行利用這個對象執行了一句SQL,并返回一個結果集。第五到八行遍歷了這個結果集并輸出數據。


析構
怎么樣,看起來不錯吧,如果你感興趣可以按照Creole站上的Guide一步一步做下去。不過我們就要做別的事情了:P 前邊說過了,Creole更多的注重于OO,同時又帶有很強的Java風格,因此對于我們學習使用PHP5來設計OO方式的程序是很好的范例。下邊我們就來看看它的架構。首先要了解的是它的目錄結構,在Windows命令行方式鍵入tree,就可以打印出一個目錄的結構(一個有用的小技巧哦),下邊是由此得到的Creole目錄結構,目錄后邊加上了簡要的說明。
我們以Statement為例,看看Creole是怎么組織的。首先在根目錄下的Statement.php中定義了Statement接口,這個接口規定了Statement必須實現的一些方法。然后,在/common目錄下的StatementCommon.php中定義了名為StatementCommon的抽象類,在這個類中,包含了Statement.php中定義的接口的實現代碼,但是并沒有定義為實現Statement接口。


Root // Creole的根目錄
├─common // 存放了Creole的抽象類
├─drivers
│ ├─mssql
│ │ └─metadata // mssql實現
│ ├─mysql
│ │ └─metadata // mysql實現
│ ├─pgsql
│ │ └─metadata
│ └─sqlite
│ └─metadata
├─metadata // 數據表原始信息類
└─util
└─sql


而在/drivers/mysql/目錄下的MysqlStatement則繼承了StatementCommon和實現Statement方法。這樣MysqlStatement可以共享到StatementCommon中的方法,需要定制時可以重載StatementCommon的方法;同時,MysqlStatement又受到Statement接口的約束。

下一頁的圖表示了Statement,StatementCommon和MysqlStatement之間的關系。正是這樣的結構,使定義和實現得到了有效的分離。Creole中大量采用了這樣的結構,在我們編寫自己的Driver時非常方便。如果要添加一個TextStatement,可以自己實現一個class,只要這個class實現了Statement接口就可以了。而Driver正是由這樣的一組class組成的。

500) this.width=500" vspace=10 border=0>



參考
我們對Creole的介紹到這里就告一個段落了,而對你來說,一切才剛剛開始。下邊是從兩個常用類的接口程序內中整理出來的方法,希望能對你有所幫助。

Statement


public function setLimit($v);
public function getLimit();
public function setOffset($v);
public function getOffset();
public function close();
public function execute($sql, $fetchmode = null);
public function getResultSet();
public function executeQuery($sql, $fetchmode = null);
public function executeUpdate($sql);
public function getMoreResults();
public function getConnection();


ResultSet


public function getResource();
public function setFetchmode($mode);
public function getFetchmode();
public function isIgnoreAssocCase();
public function next();
public function previous();
public function relative($offset);
public function absolute($pos);
public function seek($rownum);
public function first();
public function last();
public function beforeFirst();
public function afterLast();
public function isAfterLast();
public function isBeforeFirst();
public function getCursorPos();
public function getRow();
public function getRecordCount();
public function close();
public function get($column);
public function getArray($column);
public function getBoolean($column);
public function getBlob($column);
public function getClob($column);
public function getDate($column, $format = '%x');
public function getFloat($column);
public function getInt($column);
public function getString($column);
public function getTime($column, $format = '%X');
public function getTimestamp($column, $format = 'Y-m-d H:i:s');


作者簡介
Easy Chen , 04年畢業于石油大學(北京) 計算機系,ReleaseEasy/ Rticle 作者。喜好網絡技術寫作,《PHP&MORE》編輯,聯系信箱:EasyChen at Gmail.com
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲男人av在线| 欧美国产在线电影| 国产精品一区二区久久| 国产精品视频一区二区三区四| 国产精品99久久久久久白浆小说| 日本国产一区二区三区| 欧美在线国产精品| 精品日本美女福利在线观看| 夜夜躁日日躁狠狠久久88av| 97人人爽人人喊人人模波多| 欧美激情视频在线| 亚洲r级在线观看| 欧美日韩日本国产| 91系列在线播放| 两个人的视频www国产精品| 国产91免费观看| 国产精品福利久久久| 国产精品6699| 国产视频一区在线| 国产精品久久久亚洲| 最近2019中文字幕第三页视频| 视频直播国产精品| 国产精品小说在线| 久久久久久久成人| 欧美性20hd另类| 亚洲美女久久久| 亚洲精品狠狠操| 欧美另类极品videosbest最新版本| 国内成人精品一区| 91香蕉亚洲精品| 日韩中文字幕视频在线观看| 色综合视频一区中文字幕| 欧美理论电影在线播放| 久久久黄色av| 久久精品免费电影| 国产a∨精品一区二区三区不卡| 欧美性开放视频| 日本在线精品视频| 国产一区玩具在线观看| 欧美极品少妇xxxxⅹ喷水| 久久久久久尹人网香蕉| 欧美黑人巨大精品一区二区| 国产亚洲欧美日韩精品| 国产精品欧美激情在线播放| 亚洲最新在线视频| 日韩精品在线观看视频| 欧美精品videossex88| 欧美性极品少妇精品网站| 6080yy精品一区二区三区| 2018日韩中文字幕| 激情av一区二区| 欧美激情精品久久久久| 黑人精品xxx一区| 国内久久久精品| 亚洲欧洲国产一区| 国产成人精品日本亚洲| 中文字幕免费精品一区高清| 欧美福利视频在线| 国产精品久久999| 欧美日韩国产区| 欧美日韩亚洲视频一区| 久久免费视频这里只有精品| 国产精品福利无圣光在线一区| 在线精品国产成人综合| 成人午夜小视频| 精品成人国产在线观看男人呻吟| 欧美www视频在线观看| 国产视频在线一区二区| 久久影院资源站| 亚洲aⅴ日韩av电影在线观看| 色爱av美腿丝袜综合粉嫩av| 亚洲精品日韩av| 456国产精品| 97成人精品视频在线观看| 国产精品va在线播放我和闺蜜| 亚洲国产精品久久久久秋霞不卡| 欧美日韩在线免费观看| 亚洲成人精品av| 亚洲激情中文字幕| 久久久久久国产免费| 久久精品视频导航| 茄子视频成人在线| 欧美成人精品一区| 久久久久久久久久久人体| 久久亚洲综合国产精品99麻豆精品福利| 欧美日韩国产页| 97精品国产91久久久久久| 在线看国产精品| 一区二区三区 在线观看视| 精品久久久久人成| 国产福利视频一区二区| 91精品国产网站| 欧美精品一二区| 性欧美xxxx| 国产色婷婷国产综合在线理论片a| 宅男66日本亚洲欧美视频| 日产精品久久久一区二区福利| 在线观看日韩专区| 欧美激情女人20p| 亚洲一区美女视频在线观看免费| 97色在线播放视频| 欧美一性一乱一交一视频| 久久精品亚洲精品| 日韩精品999| 国产精品91视频| 日韩精品亚洲精品| 欧美成人免费va影院高清| 欧美最近摘花xxxx摘花| 国产女人精品视频| 日本在线精品视频| 亚洲图片在线综合| 久久久精品视频成人| 国产福利精品视频| 91精品免费久久久久久久久| 91高清免费在线观看| 隔壁老王国产在线精品| 欧美极品少妇xxxxⅹ喷水| 国产精品96久久久久久又黄又硬| 欧美在线视频a| 国产精品69久久久久| 一本色道久久88精品综合| 欧美日韩免费一区| 亚洲一级一级97网| 啪一啪鲁一鲁2019在线视频| 伊人久久久久久久久久久| 久久精品国产v日韩v亚洲| 色综合久综合久久综合久鬼88| 亚洲欧洲国产伦综合| 日韩在线播放av| 尤物yw午夜国产精品视频明星| 97福利一区二区| 精品久久久精品| 久久天堂av综合合色| 欧美亚洲另类在线| 久久精品电影一区二区| 欧美极品在线视频| 亚洲男人天堂网站| 亚洲天堂免费视频| 亚洲黄在线观看| 97精品视频在线| 国产91精品黑色丝袜高跟鞋| 亚洲欧美日韩精品久久| 国产裸体写真av一区二区| 欧美性生交xxxxx久久久| 久久久免费观看视频| 久久久国产精彩视频美女艺术照福利| 国产精品久久一区主播| 久久免费精品日本久久中文字幕| 国产日韩欧美在线看| 国产视频999| 91九色精品视频| 久久精品成人欧美大片| 在线亚洲国产精品网| 成人444kkkk在线观看| 国产区亚洲区欧美区| 亚洲乱码一区av黑人高潮| 色在人av网站天堂精品| 亚洲精品日韩激情在线电影| 国产精品视频xxxx| 69av视频在线播放| 欧美成人免费全部| 久久精品亚洲热| 97碰碰碰免费色视频| 亚洲美女免费精品视频在线观看|