初學(xué)postgresql,想安裝一個在本機測試一下,環(huán)境為windows xp + apache2 + php5(5.2.6) + postgresql8.4.一切安裝正常,但是再裝上phppgadmin測試時,顯示“您的 PHP 中沒有完整的數(shù)據(jù)庫支持”。apache錯誤日志為“PHP Warning: PHP Startup: Unable to load dynamic library 'C:/php/ext/php_pgsql.dll'”。多次在網(wǎng)上搜索解決方法,已完成以下操作:

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比臨渭區(qū)網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式臨渭區(qū)網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋臨渭區(qū)地區(qū)。費用合理售后完善,10年實體公司更值得信賴。
1、修改php.ini
2、確認C:\php\ext\下php_pgsql.dll存在
3、修改path環(huán)境變量,添加了postgresql的bin目錄
4、將libpg.dll放至windows\system32下
5、重啟apache多次
不好意思,僅有的一點積分已經(jīng)用光了,所以只好請大家多多支持了。
cmd下,cd到php所在目錄,之后在cmd下運行 php 看提示吧,卻啥lib它會提示你,需要啥去pgsql下cpoy到windows\system32下,你只復(fù)制一個libpg.dll是不夠的,好象復(fù)制好多個
thinkphp連接數(shù)據(jù)庫的方法:
ThinkPHP內(nèi)置了抽象數(shù)據(jù)庫訪問層,把不同的數(shù)據(jù)庫操作封裝起來,只需要使用公共的Db類進行操作,而無需針對不同的數(shù)據(jù)庫寫不同的代碼和底層實現(xiàn),Db類會自動調(diào)用相應(yīng)的數(shù)據(jù)庫驅(qū)動來處理。目前的數(shù)據(jù)庫包括Mysql、SqlServer、PgSQL、Sqlite、Oracle、Ibase、Mongo,也包括對PDO的支持,如果應(yīng)用需要使用數(shù)據(jù)庫,必須配置數(shù)據(jù)庫連接信息,數(shù)據(jù)庫的配置文件有多種定義方式。
常用的配置方式是在項目配置文件中添加下面的參數(shù):
?php
//項目配置文件
return array(
//數(shù)據(jù)庫配置信息
'DB_TYPE' = 'mysql', // 數(shù)據(jù)庫類型
'DB_HOST' = 'localhost', // 服務(wù)器地址
'DB_NAME' = 'thinkphp', // 數(shù)據(jù)庫名
'DB_USER' = 'root', // 用戶名
'DB_PWD' = '', // 密碼
'DB_PORT' = 3306, // 端口
'DB_PREFIX' = 'think_', // 數(shù)據(jù)庫表前綴
//其他項目配置參數(shù)
// ...
);
需要注意的是,ThinkPHP的數(shù)據(jù)庫連接的惰性的,所以并不是在實例化的時候就連接數(shù)據(jù)庫,而是在有實際的數(shù)據(jù)操作的時候才會去連接數(shù)據(jù)庫(額外的情況是,在系統(tǒng)第一次實例化模型的時候,會自動連接數(shù)據(jù)庫獲取相關(guān)模型類對應(yīng)的數(shù)據(jù)表的字段信息)。
php.ini中將extension=php_pgsql.dll前面的分號去掉,然后設(shè)置extension_dir指向php文件下的ext文件夾。
或者直接把將./php/libpq.dll(php文件夾下的libpq.dll)和./php/ext/php_pgsql.dll(ext文件夾下的php_pgsql.dll)這兩個dll文件復(fù)制到C盤system32下。
正常情況下這樣php就可以連接postgres了,但是我的仍然出錯,提示“Fatal error: Call to undefined function pg_connect()”,查看Apache的日志,“PHP Startup: Unable to load dynamic library '****\\PHP5\\ext\\php_pdo_pgsql.dll”。
經(jīng)過查找,在Apache中conf文件夾下的配置文件httpd.conf中添加 LoadFile "***/PHP5/libpq.dll",位置在LoadModule后面即可。
(***為php安裝路徑)
測試代碼:
?php
$conn_string = "host=localhost port=5432 dbname=db_name user=your user password=your password" ;
$dbconn = pg_connect($conn_string);
if (!$dbconn)
echo "連接失敗!!!!!/r/n";
else
echo "連接成功!!!!!/r/n";
pg_close($dbconn);
?
user一般為安裝期間新建的用戶postgres
連接數(shù)據(jù)庫 ThinkPHP內(nèi)置了抽象數(shù)據(jù)庫訪問層,把不同的數(shù)據(jù)庫操作封裝起來,我們只需要使用公共的Db類進行操作,而無需針對不同的數(shù)據(jù)庫寫不同的代碼和底層實現(xiàn),Db類會自動調(diào)用相應(yīng)的數(shù)據(jù)庫適配器來處理。目前的數(shù)據(jù)庫包括Mysql、MsSQL、PgSQL、Sqlite、Oracle、Ibase以及PDO的支持,如果應(yīng)用需要使用數(shù)據(jù)庫,必須配置數(shù)據(jù)庫連接信息,數(shù)據(jù)庫的配置文件有多種定義方式:
第一種 在項目配置文件里面定義
return array(
'DB_TYPE'= 'mysql',
'DB_HOST'= 'localhost',
'DB_NAME'='thinkphp',
'DB_USER'='root',
'DB_PWD'='',
'DB_PORT'='3306',
'DB_PREFIX'='think_',
// 其他項目配置參數(shù)………
);
系統(tǒng)推薦使用該種方式,因為一般一個項目的數(shù)據(jù)庫訪問配置是相同的。該方法系統(tǒng)在連接數(shù)據(jù)庫的時候會自動獲取,無需手動連接。
可以對每個項目定義不同的數(shù)據(jù)庫連接信息,還可以在調(diào)試配置文件(Conf/debug.php)里面定義調(diào)試數(shù)據(jù)庫的配置信息,如果在項目配置文件和調(diào)試模式配置文件里面同時定義了數(shù)據(jù)庫連接信息,那么在調(diào)試模式下面后者生效,部署模式下面前者生效。
第二種 使用DSN方式在初始化Db類的時候傳參數(shù)
$db_dsn = “mysql://username:passwd@localhost:3306/DbName”;
$db = new Db($db_dsn);
該方式主要用于在控制器里面自己手動連接數(shù)據(jù)庫的情況,或者用于創(chuàng)建多個數(shù)據(jù)庫連接。
第三種 使用數(shù)組傳參數(shù)
$DSN = array(
'dbms' = 'mysql',
'username' = 'username',
'password' = 'password',
'hostname' = ; 'localhost',
'hostport' = '3306',
'database' = 'dbname'
);
$db = new Db($DSN);
該方式也是用于手動連接數(shù)據(jù)庫的情況,或者用于創(chuàng)建多個數(shù)據(jù)庫連接。
第四種 在模型類里面定義
protected $connection = array(
'dbms' = 'mysql',
'username' = 'username',
'password' = 'password',
'hostname' = 'localhost',
'hostport' = '3306',
'database' = 'dbname'
);
// 或者使用下面的定義
protected $connection = ”mysql://username:passwd@localhost:3306/DbName”;
如果在某個模型類里面定義了connection屬性,則在實例化模型對象的時候,會使用該數(shù)據(jù)庫連接信息進行數(shù)據(jù)庫連接。通常用于某些數(shù)據(jù)表位于當前數(shù)據(jù)庫連接之外的其它數(shù)據(jù)庫。
ThinkPHP并不是在一開始就會連接數(shù)據(jù)庫,而是在有數(shù)據(jù)查詢操作的時候才會去連接數(shù)據(jù)庫。額外的情況是,在系統(tǒng)第一次操作模型的時候,框架會自動連接數(shù)據(jù)庫獲取相關(guān)模型類的數(shù)據(jù)字段信息,并緩存下來。
(字段緩存目錄:Runtime/Data/_fields)
ThinkPHP支持PDO方式,如果要使用PDO方式連接數(shù)據(jù)庫,可以參考下面的設(shè)置。
我們以項目配置文件定義為例來說明:
return array(
'DB_TYPE'= 'pdo',
// 注意DSN的配置針對不同的數(shù)據(jù)庫有所區(qū)別 請參考PHP手冊PDO類庫部分
'DB_DSN'= 'mysql:host=localhost;dbname=think',
'DB_USER'='root',
'DB_PWD'='',
'DB_PREFIX'='think_',
// 其他項目配置參數(shù)………
);
使用PDO方式的時候,要注意檢查是否開啟相關(guān)的PDO模塊。DB_DSN參數(shù)僅對PDO方式連接才有效。
文章標題:php連接pg數(shù)據(jù)庫 pgadmin連接數(shù)據(jù)庫
分享路徑:http://chinadenli.net/article22/hhjojc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、企業(yè)網(wǎng)站制作、網(wǎng)站內(nèi)鏈、移動網(wǎng)站建設(shè)、微信小程序、品牌網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)