Mysql資料庫連接、查詢、記錄集作業碼

來源:互聯網
上載者:User

標籤:

Mysql資料庫連結代碼
function dbConnect($hostname,$username,$pass,$db_name,$pconnect=0){    $func=empty($pconnect) ? ‘mysql_connect‘:‘mysql_pconnect‘;       if(!$connect){        [email protected]$func($hostname,$username,$pass) or die("<font size=‘2‘>Mysql_Error : ".mysql_error()."<br>Mysql Error Num : ".mysql_errno()."</font>");                 }       @mysql_select_db($db_name,$connect) or die("<font size=‘2‘> Mysql_Error : ".mysql_error()."<br>Mysql Error Num : ".mysql_errno()."</font>");    return $connect;}

 

注釋

參 數$hostname,$username,$pass,$db_name分別代表Mysql資料庫伺服器地址,使用者名稱,密碼,以及串連的資料庫名,通常 情況下hostname一般都是localhost或者127.0.0.1。參數$pconnect預設為0,表示通常情況下是以 mysql_connect函數串連Mysql資料庫。

 

知識點

mysql_connect與mysql_pconnect的區別: 當執行完當前PHP程式後,PHP自動關閉mysql_connect建立的資料庫連接,而mysql_pconnect返回一個持久穩固的資料庫連接, 在一定時間內有下一個串連請求時可以被複用,節省了反覆串連Mysql資料庫的時間,使得訪問速度加快,其適用於並發訪問量不大的情況,如並發訪問量比較 大,則可能會因為Mysql已達到最大串連數, 使之後的請求得不到滿足。

mysql_error函數:返回上一個Mysql操作產生的文本錯誤資訊。mysql_errno函數返回上一個Mysql操作中的錯誤號碼,如果沒有出錯則返回0。

 Mysql資料庫查詢代碼

function query_error($query){    global$connect;    $temp_bar="<br>=============================================================================<br>";    $result=mysql_query($query,$connect) or die("DB ERROR <br>".$temp_bar."<font size=‘2‘> Mysql_Query : ".$query."<br> Mysql_Error : ".mysql_error()."<br> Mysql Error Num : ".mysql_errno()."</font>".$temp_bar);    return$result;}

 

注釋:此函數為Mysql資料庫查詢函數,等於同mysql_query函數的功能,如果出錯則輸出出錯資訊(SQL語句),其實為了防止暴露網站資料庫的結構,正式商用時,最好不要輸出SQL執行語句。

Mysql記錄集操作函數代碼(mysql_fetch_array)

function fetch_array($result,$result_type= MYSQL_ASSOC,$records="one"){    if($records=="one"){        return@mysql_fetch_array($result,$result_type);    }    else{        for($i=0;num_rows($result);$i++)        {            $info[$i]=@mysql_fetch_array($result,$result_type);        }               free_result($result);               return$info;    }}

 

注釋:此函數的功能由mysql_fetch_array函數延生而來,在此基礎上我增加了對Mysql資料庫記錄集的讀取功能,並以數組形式返回擷取的值。

知識點

mysql_fetch_array函數是mysql_fetch_row函數的擴充版本。第二個參數 result_type有三個值:MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。預設值是 MYSQL_BOTH。MYSQL_BOTH:得到一個同時包含關聯和數字索引的數組。MYSQL_ASSOC:只得到關聯索引(如同mysql_fetch_assoc()那樣),MYSQL_NUM :得到數字索引(如同 mysql_fetch_row()那樣)。

報錯資訊函數代碼

function error_msg($msg,$url=""){    global$connect;    if($connect){        mysql_close($connect);    }    switch($url)    {        case"":            $url="history.go(-1)";            break;        case"close":            $url="window.close()";            break;        default:            $url="document.location.href = ‘$url‘";            break;     }       if(!empty($msg)){        echo"<script language=‘javascript‘>alert(‘$str‘);$url;</script>";    }    else{        echo"<script language=‘javascript‘>$url;</script>";    }    exit;}

 

注釋:此函數的功能主要以alert的形式報錯並進行頁面跳轉,是一個通用函數,報錯或跳轉之前其會先將Mysql資料庫連接關閉,用到了mysql_close函數。

調用說明

從上述Mysql資料庫操作的函數代碼中,我們可以看到$connect變數是一個全域變數,首先將上述幾個函數放入一個檔案,如mysqlconnect.php中,然後在聲明相關變數並賦值,在dbConnect函式宣告後調用此Mysql資料庫連接函數,即:

$hostname="mysqlserveraddr";$username="yourusername";$pass="youruserpass";$db_name="yourdatabase";$connect= dbConnect($hostname,$username,$pass,$db_name);

 總結:

  通過上面幾個Mysql資料庫連接、資料庫查詢、資料庫記錄集操作函數代碼的講解,在PHP網站開發中Mysql資料庫操作的基本函數已包括,根據需要可在此代碼基礎上改成Mysql資料庫類或者利用PHP添加其他的Mysql資料庫操作函數都是可行的

 

Mysql資料庫連接、查詢、記錄集作業碼

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.