關於PHP建立資料庫訪問類的封裝以及操作php單例模式連接資料庫封裝類

来源:http://www.cnblogs.com/jly144000/archive/2017/09/03/7471669.html
-Advertisement-
Play Games

建立資料庫訪問類的封裝 <?php class DBDA { public $host = "localhost"; //伺服器地址 public $uid = "root"; //資料庫的用戶名 public $pwd = ""; //資料庫的密碼 public $dbname = "";//數據 ...


建立資料庫訪問類的封裝 <?php   class DBDA {     public $host = "localhost"; //伺服器地址     public $uid = "root"; //資料庫的用戶名     public $pwd = ""; //資料庫的密碼     public $dbname = "";//資料庫名           //執行SQL語句,返回相應結果的函數     //$sql是要執行的SQL語句     //$type是SQL語句的類型,0代表增刪改,1代表查詢     //$db代表要操作的資料庫     public function Query($sql,$type=1,$db="xm_youxiang")     {         //造連接對象         $conn = new MySQLi($this->host,$this->uid,$this->pwd,$db);                   //判斷連接是否成功         !mysqli_connect_error() or die("連接失敗!");                   //執行SQL語句         $result = $conn->query($sql);                   //判斷SQL語句類型         if($type==1)         {             //如果是查詢語句返回結果集的二維數組             return $result->fetch_all();         }         else         {             //如果是其他語句,返回true或false             return $result;         }     } 單例模式連接資料庫封裝類

單例模式有三大原則:

構造函數不能為public

有一個保存實例的靜態成員變數

擁有訪問這個實例的公共靜態方法

基於單例模式的PHP資料庫連接類:

class DB{
    static private $a;  //實例變數
    static private $b;  //
    private $dbquery = array(
        'host' => 'localhost',
        'uid' => 'root',
        'password' => '',
        'dbname' =>'資料庫名',
    );
    private function __construct(){

    }
    static public function show(){
        if(!(self::$a aof self)){
            self::$a = new self();
        }
        return self::$a;
    }

    public function connect(){
        if(!self::$b){
            self::$b = mysql_connect($this->dbquery['host'],$this->dbquery['uid'],$this->dbquery['password']);
            if(!self::$b){
                die('mysql error'.mysql_error());
            }

            //mysql_select_db($this->dbquery['dbname'],self::$b);
           //mysql_query("set names UTF8",self::$b);
        }
        return self::$b;
    }
}
使用時直接實例化 eg:$connect = DB::show()->connect();  
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 以下是我根據自身的情況來總結的ASP.NET 知識體系 ...
  • Response.Write 、RegisterClientScriptBlock和RegisterStartupScript總結 Page.ClientScript.RegisterStartupScript用法小結 原文鏈接:http://blog.csdn.net/qiujialongjjj/ ...
  • 套用mui官方文檔的一句話:“開發者只需關心業務邏輯,實現載入更多數據即可”。真的是不錯的框架。 想更多的瞭解這個框架:http://dev.dcloud.net.cn/mui/ 那麼如何實現下拉刷新,上拉載入的功能呢? 首先需要一個容器: 然後進行初始化操作,通過mui.init方法中pullRe ...
  • 一、WCF技術我該如何學習? 阿笨的回答是:作為初學者的我們,那麼請跟著阿笨一起玩WCF吧,阿笨將帶領大家如何以正確的姿勢去掌握WCF技術。由於WCF技術知識點太多了,就純基礎概念性知識都可以單獨出一本書來講解,本次分享課程《C#面向服務編程技術WCF從入門到實戰演練》開課之前,阿笨還是希望從沒瞭解 ...
  • 開篇先來說一下我和來畫的故事,以及寫這篇文章的初衷。 今年年初時,我還在北京,在 Face++,做著人臉識別技術的 Windows 和 Android 端,做著人工智慧終將實現世間所有美好的夢。這時的我已經離開 UWP,甚至 C# 很久了,寫著 C++ 和 Java,當時真的沒想過會再次回到 UWP ...
  • 自己畫一個轉圈圈的控制項 ...
  • 首先說一下foreach有的也叫增強for迴圈,foreach其實是for迴圈的一個特殊簡化版。 再說一下foreach的書寫格式: for(元素類型 元素名稱 : 遍曆數組(集合)(或者能進行迭代的)){ 語句 } foreach雖然是for迴圈的簡化版本,但是並不是說foreach就比for更好 ...
  • 特別聲明本隨筆copy於egon(林海峰)。 一 IO模型介紹 為了更好地瞭解IO模型,我們需要事先回顧下:同步、非同步、阻塞、非阻塞 同步(synchronous) IO和非同步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分別是什麼,到底有 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...