新聞中心
PHP訪問MySQL數(shù)據(jù)庫的步驟。
PHP訪問MySQL數(shù)據(jù)庫:
創(chuàng)新互聯(lián)公司主營巴里坤哈薩克網(wǎng)站建設(shè)的網(wǎng)絡公司,主營網(wǎng)站建設(shè)方案,app軟件開發(fā)公司,巴里坤哈薩克h5小程序制作搭建,巴里坤哈薩克網(wǎng)站營銷推廣歡迎巴里坤哈薩克等地區(qū)企業(yè)咨詢
因為連接數(shù)據(jù)庫需要較長的時間和較大的資源開銷,所以如果在多個網(wǎng)頁中都要頻繁地訪問數(shù)據(jù)庫,則可以建立與數(shù)據(jù)庫的持續(xù)連接。即調(diào)用mysql_pconnect()代替mysql_connect()。
基本步驟:
1.連接服務器:mysql_connect();
2.選擇數(shù)據(jù)庫:mysql_select_db();
3.執(zhí)行SQL語句:mysql_query();
查詢:select
顯示:show
插入:insert into
更新:update
刪除:delete
4.關(guān)閉結(jié)果集:mysql_free_result($result);
5.關(guān)閉數(shù)據(jù)庫:mysql_close($link);
PHP7連接mysql數(shù)據(jù)庫方法
1、用 mysql_connect 的方法,PHP7會報致命錯誤
$conn= mysql_connect('localhost','xueyanxiang','xueyanxiang');
Fatal error : Uncaught Error: Call to undefined function mysql_connect() in /Users/xueyanxiang/work/test/xue.php:31 Stack trace: #0 /Users/xueyanxiang/work/test/xue.php(119): xue-run() #1 {main} thrown in? /Users/xueyanxiang/work/test/xue.php ?on line? 31
原因是:
PHP5中使用mysql_connect()函數(shù)進行連接,但實際上,PHP5.5開始,MySQL就不推薦使用了,屬于廢棄函數(shù)
PHP7中貌似已經(jīng)徹底不支持了,根據(jù)官網(wǎng)說明,取而代之的是如下兩個:
本擴展自 PHP 5.5.0 起已廢棄,并在將來會被移除。應使用?MySQLi?或?PDO_MySQL?擴展來替換之。參見?MySQL:選擇
API?指南以及相關(guān) FAQ?以獲取更多信息。用以替代本函數(shù)的有:
mysqli_connect()
PDO::__construct()
使用時,不要在使用mysql_connect了,可以換用mysqli_connect(),用法基本類似吧,據(jù)說是面向?qū)ο蟮膸臁?/p>
php.ini中,也只有extension=php_mysqli.dll,而不再有extension=php_mysql.dll這個拓展了。
2、可以使用mysqli,對象化,方法名與被廢棄的類似
$conn= mysqli_connect('localhost','xueyanxiang','xueyanxiang');
3、PDO工具,推薦使用
$dbh= "mysql:host=localhost;dbname=test";
$db= new PDO($dbh,'xueyanxiang','xueyanxiang');
$objQuery= $db-query("select * from user;");
$res= $objQuery-fetchAll(PDO::FETCH_ASSOC);
不填寫參數(shù)的話,默認是關(guān)聯(lián)和索引都有,如下圖
PHP7.0打開擴展功能要怎樣才能和mysql相連?
第一步:進入php源碼中的"ext/mysql"目錄下
第二步:在當前目錄下運行phpize命令:/usr/local/php524/bin/phpize
phpize的規(guī)則:去哪個目錄下運行phpize文件,那么就會在該目錄下生成一個configure文件。
第三步:運行剛才生成的configure文件
命令: ./configure --with-php-config=/usr/local/php524/bin/php-config --with-mysql=/usr/local/mysql/
這里最關(guān)鍵的是通過--with-mysql參數(shù)告訴mysql客戶端的位置。這樣才能生成mysql.so。
實驗的時候,沒有加這個參數(shù),結(jié)果錯誤:
./configure --with-php-config=/usr/local/php524/bin/php-config
第四步:編譯生成.so文件
第五步:配置php引擎加載該擴展。
補充一下:就是去php.ini文件中修改一下配置,加載mysql.so這個擴展(這個擴展文件要放到php指定的擴展目錄下面去)
第六步:測試php引擎是否成功加載該擴展編寫文件phpinfo.php,內(nèi)容是:?php?ehco phpinfo();??
運行后,可以看到有如下信息顯示:mysqlMySQLSupport ? ?enabledActive PersistentLinks ? ? 0
Active Links ? ? 0
Client API version ? ? 5.1.55
MYSQL_MODULE_TYPE ? ? no value
MYSQL_SOCKET ? ? /tmp/mysql.sock
MYSQL_INCLUDE ? ? no value
MYSQL_LIBS ? ? no value
通過這樣的方式可以確認,php引擎已經(jīng)成功加載了mysql.so擴展。
第七步:已經(jīng)生成的mysql.so。編寫php代碼測試是否能連接mysql。
一、為什么書中一般是常常是這樣的順序安裝。
先安裝mysql,然后再安裝php,很少看到先安裝php,后安裝mysql?
這樣做。是基于下面原因:安裝好mysql后。mysql.so這個模塊才能生成。記得一個細節(jié):在安裝php的時候,需要提供mysql的路徑。由php幫助編譯生成mysql.so模塊。mysql.so這個模塊是在安裝好php的時候生成的。
生成這個模塊需要用到一個東西:mysql客戶端。如果先安裝php,后安裝mysql。那么無法按照原來的方式(由php幫助生成mysql.so模塊)掛接mysql.so。通過實踐,發(fā)現(xiàn)使用phpize工具生成mysql.so可以解決這個問題。
二、實踐生成mysql.so的過程。
大體思路:需要用到php的源碼包才行。通過源碼包中提供的phpize文件(一個專門掛接php擴展的工具)
dw中php怎么連接mysql數(shù)據(jù)庫
首先打開DW,找到數(shù)據(jù)庫 選項卡:
這里是說,要完成連接數(shù)據(jù)庫操作 需要完成3步。那么好,我們按步驟來做:
1、搞定創(chuàng)建站點
點擊藍色“站點”,彈出如下界面
站點命名
服務器技術(shù)
編輯和測試文件存放位置,我們都在本地開發(fā)的,所以都在本地文件存在的位置就選你網(wǎng)站代碼的位置
定義瀏覽器打開預覽時url路徑,我這里是:,注意這個路徑一定是可以訪問的路徑,就是在瀏覽器中能打開,否則4步的mysql會報連接不成功的操作
是否共享文件,這個是用來團隊開發(fā)的,點否
OK,下一步,完成,收功。這樣我們就完成了第一步,多出來一個√,增加了一個第四步。
2、搞定文檔類型
點擊藍色“文檔類型”,彈出如下界面
我們用的PHP,這里選擇PHP
完成,ok,第二步搞定??从侄喑鲆粋€√。
3、搞定測試服務器
點擊藍色“測試服務器”,彈出如下界面
顯示我們第一步已經(jīng)配置過的內(nèi)容,直接點確認
完成,ok,但是并沒有按照預想多出一個√,沒事,繼續(xù)。
4、創(chuàng)建MYSQL連接
點擊上圖紅色箭頭指的+,出來Mysql連接,點擊,彈出如下界面
依次輸入你本地的信息,如我這里輸入的
然后點選取,彈出你的數(shù)據(jù)庫,選擇你的項目news所用的數(shù)據(jù)庫。確定,確定,ok,完成。
怎么將php與數(shù)據(jù)庫連接
php鏈接mysql必備條件:
已安裝mysql數(shù)據(jù)庫;
檢查php環(huán)境是否已開啟mysql擴展(一般情況下是開啟的);
檢查方法:a.使用phpinfo();函數(shù),看有沒有mysql項;b.打開php.ini文件,檢查php_mysql.dll前分號是否已取掉。
php鏈接代碼如下:
?php
//設(shè)置編碼格式
header("Content-type:text/html;charset=utf-8");
//定義數(shù)據(jù)庫主機地址
$host="localhost";
//定義mysql數(shù)據(jù)庫登錄用戶名
$user="root";
//定義mysql數(shù)據(jù)庫登錄密碼
$pwd="";
//鏈接數(shù)據(jù)庫
$conn = mysql_connect($host,$user,$pwd);
//對連接進行判斷
if(!$conn){
die("數(shù)據(jù)庫連接失敗!".mysql_errno());
}else{
echo "數(shù)據(jù)庫連接成功!";
}
?
本文標題:php7連接數(shù)據(jù)庫的步驟,php與數(shù)據(jù)庫的連接
文章源于:http://fisionsoft.com.cn/article/hespci.html