亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP連接MySql數(shù)據(jù)庫(kù)方法簡(jiǎn)化版

 更新時(shí)間:2022年07月25日 16:04:40   作者:清風(fēng)亦思雨  
MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),由瑞典MySQL?AB?公司開(kāi)發(fā),屬于?Oracle?旗下產(chǎn)品。MySQL?是最流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)之一,這篇文章主要介紹了PHP連接mysql數(shù)據(jù)庫(kù),數(shù)據(jù)庫(kù)連接靜態(tài)工具類,簡(jiǎn)化連接

寫這個(gè)PHP連接數(shù)據(jù)庫(kù)靜態(tài)工具類之前,是由于當(dāng)時(shí)學(xué)習(xí)C#的asp.net。老師編寫了一個(gè)連接數(shù)據(jù)庫(kù)的靜態(tài)工具類,發(fā)現(xiàn)使用此類,每次只需要寫sql語(yǔ)句,而不再需要進(jìn)行連接創(chuàng)建,關(guān)閉等等。方便其他操作,節(jié)約時(shí)間。

轉(zhuǎn)眼一年半,如今php課程需要寫一個(gè)小項(xiàng)目,于是第一件事就是編寫一個(gè)連接數(shù)據(jù)庫(kù)的靜態(tài)工具類,php和asp.net的語(yǔ)法極其的相似。

在使用此類之前,可以普及兩點(diǎn)知識(shí):

PHP中使用靜態(tài)的調(diào)用,不同于其他編程語(yǔ)言,它的靜態(tài)調(diào)用為:

類名::$靜態(tài)屬性

類名::靜態(tài)方法()

而Java、C#等編程語(yǔ)言都是通過(guò):

類名.靜態(tài)屬性

類名.靜態(tài)方法()

靜態(tài)方法的優(yōu)點(diǎn):

(1)在代碼的任何地方都可以用,不需要實(shí)例對(duì)象就能訪問(wèn)靜態(tài)屬性或方法;

(2)類的每個(gè)實(shí)例都可以訪問(wèn)類中定義的靜態(tài)屬性,可以利用靜態(tài)屬性來(lái)設(shè)置值,該值可以被類的所有對(duì)象使用,方便控制數(shù)據(jù)庫(kù)參數(shù),連接對(duì)象的創(chuàng)建與關(guān)閉;

DBHelper.php 靜態(tài)工具類

<?php
    /**該P(yáng)HP文件為了連接數(shù)據(jù)庫(kù)方便
     * 為連接數(shù)據(jù)庫(kù)提供靜態(tài)方法
     */
    header("Content-type: text/html;charset=utf-8");
    class DBHelper {
        static $sqlName = "127.0.0.1";
        static $userName = "root";
        static $passWord = "123456";
        static $dbName = "test";
        //連接數(shù)據(jù)庫(kù)
        static function dbConn() {
            $conn = mysqli_connect(self::$sqlName, self::$userName,
                    self::$passWord, self::$dbName);
            if ($conn == false) {
                echo "<script>alert('數(shù)據(jù)庫(kù)連接失敗')</script>";
            }
            //設(shè)置連接對(duì)象編碼
            mysqli_query($conn, "set names utf8");
            return $conn;
        }
        //查詢數(shù)據(jù)
        //param1:查詢類型,param2:執(zhí)行語(yǔ)句
        //param1參數(shù)類型:  0單個(gè)數(shù)組,1多個(gè)數(shù)組。
        static function select($state, $mysql):array {
            $conn = self::dbConn(); //獲得連接對(duì)象
            $sql = $mysql;
            $query = mysqli_query($conn, $sql);
            if ($state == 1) {
                $result = mysqli_fetch_all($query,MYSQLI_ASSOC);
            } else {
                $result = mysqli_fetch_assoc($query);
            }
            // 釋放結(jié)果集
            mysqli_free_result($query);
            self::dbClose($conn); //釋放連接對(duì)象
            if ($result == null) { //如果結(jié)果為空,則返回空數(shù)據(jù)集
                return array();
            }
            return $result;
        }
        //增加、刪除、修改數(shù)據(jù)
        //param1:執(zhí)行類型;param2:執(zhí)行語(yǔ)句
        //param1參數(shù)類型:1增加,2修改,3刪除。
        static function sqlHelper($state, $mysql):int {
            $conn = self::dbConn(); //獲得連接對(duì)象
            $sql = $mysql;
            $query = mysqli_query($conn, $sql);
            //判斷狀態(tài),做出相應(yīng)提示。
            //$sts = $state==3?"刪除":($state==2?"修改":($state==1?"增加":$state));
            self::dbClose($conn); //釋放連接對(duì)象
            if ($query){
                return 1;  //有內(nèi)容變化
                //return $sts."成功";
            }
            else{
                return 0;  //無(wú)內(nèi)容變化
                //return $sts."失敗";
            }
        }
        //關(guān)閉連接
        static function dbClose($conn) {
            $conn ->Close();
        }
    }
?>

Test.php 用來(lái)測(cè)試數(shù)據(jù)

//查詢單個(gè)數(shù)據(jù)
$select = DBHelper ::select(0, "select * from XXX where xx = '$xx'");
//查詢多個(gè)數(shù)據(jù)
$selectAll = DBHelper ::select(1,"select * from XXX");
//添加數(shù)據(jù)
$insert = DBHelper ::sqlHelper(1, "insert into XXX (xx,xx,xx) values ('$xx','$xx','$xx')");
//修改數(shù)據(jù)
$update = DBHelper ::sqlHelper(2, "update XXX set xx = '$xx',xx = '$xx',xx = '$xx', where xx = '$xx'");
//刪除數(shù)據(jù)
$delete = DBHelper ::sqlHelper(3, "delete from XXX where xx = '$xx'");

前兩條測(cè)試數(shù)據(jù),都是查詢,設(shè)置的返回參數(shù)分別為mysqli_fetch_assoc、mysqli_fetch_all,這兩個(gè)參數(shù)返回的都是array,只不過(guò)里面有單個(gè)數(shù)據(jù)或多個(gè)數(shù)據(jù)。

mysqli_fetch_assoc:

mysqli_fetch_all:

后三條對(duì)應(yīng)的是增刪改,返回的int類型參數(shù),可以判斷執(zhí)行是否成功。

到此這篇關(guān)于PHP連接MySql數(shù)據(jù)庫(kù)方法簡(jiǎn)化版的文章就介紹到這了,更多相關(guān)PHP連接MySql內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論