用單例模式封裝實現乙個資料庫類

2021-08-10 11:56:22 字數 3571 閱讀 4358

使用單例模式的出發點:  

1、php的應用主要在於資料庫應用, 所以乙個應用中會存在大量的資料庫操作, 使用單例模式, 則可以避免大量的new 操作消耗的資源。

2、如果系統中需要有乙個類來全域性控制某些配置資訊, 那麼使用單例模式可以很方便的實現. 這個可以參看zf的frontcontroller部分。

3、在一次頁面請求中, 便於進行除錯, 因為所有的**(例如資料庫操作類db)都集中在乙個類中, 我們可以在類中設定鉤子, 輸出日誌,從而避免到處var_dump, echo。

創造單例注意:

1、乙個雷只能有乙個類物件(只能例項化乙個物件)

2、它必須自己建立這個例項

3、它必須自行向整個系統提供這個例項

4、建構函式和轉殖函式必須宣告為私有的,這是為了防止外部程式 new 類從而失去單例模式的意義

5、 getinstance()方法必須宣告為公有的,必須呼叫此方法以返回唯一例項的乙個引用

6、擁有乙個儲存類的例項的靜態成員變數

7、php的單例模式是相對而言的,因為php的解釋執行機制使得每個php頁面被解釋執行後,所有的相關資源都會被**

8、擁有乙個訪問這個例項的公共的靜態方法(常用getinstance()方法進行例項化單例類,通過instanceof操作符可以檢測到類是否已經被例項化)

另外,需要建立__clone()方法防止物件被複製(轉殖)

**如下:

1 <?php

2 class danli

3 13

14 //建立__clone方法防止物件被複製轉殖

15 public function __clone()

16

19 20 //單例方法,用於訪問例項的公共的靜態方法

21 public static function getinstance()

22

26 return self::$_instance;

27 }

28 29 public function test()

30

33 34 }

35 36 /*用new例項化private標記建構函式的類會報錯

37 $danli = new danli();

38 39 複製(轉殖)物件將導致乙個e_user_error

40 $danli_clone = clone $danli;

41 */

42 43

44 //正確方法,用雙冒號::操作符訪問靜態方法獲取例項

45 $danli = danli::getinstance();

46 $danli->test();

47 ?>

運用單例模式實現乙個資料庫類:

1<?php

2 class dbhelper

3 16 private function __clone()

17

19 public static function get_class_nmdb($host, $username, $password)

20

27 return self::$_instance;

28 }

29 // 連線資料表

30 public function select_db($database)

31

35 // 執行sql語句

36 public function query($query)

37

40 // 將結果集儲存為陣列

41 public function fetch_array($fetch_array)

42

45 // 獲得記錄數目

46 public function num_rows($query)

47

50 // 關閉資料庫連線

51 public function close()

52

55 }

56 $connector = dbhelper::get_class_nmdb($host, $username, $password);

57 $connector -> select_db($database);

58 ?>

1 <?php

2 /*

3 * mysql 單例

4 */

5 class mysql else

24 mysql_select_db($this->database) or $this->err();

25 $this->query("set names ''", $this->link);

26 return $this->link;

27 }

28 /**

29 * 防止被轉殖

30 *

31 */

32 private function __clone(){}

33 public static function getinstance($pconnect = false)

37 return self::$_instance;

38 }

39 /**

40 * 查詢

41 */

42 public function query($sql, $link = '')

46 /**

47 * 單行記錄

48 */

49 public function getrow($sql, $type = mysql_assoc)

53 /**

54 * 多行記錄

55 */

56 public function getrows($sql, $type = mysql_assoc)

61 return $this->rows;

62 }

63 /**

64 * 錯誤資訊輸出

65 */

66 protected function err($sql = null)

71 }

72 //用例

73 $db = mysql::getinstance();

74 $db2 = mysql::getinstance();

75 $data = $db->getrows('select * from blog');

76 //print_r($data);

77 //判斷兩個物件是否相等

78 if($db === $db2)

81 ?>

用單例模式來設計乙個PHP資料庫類

class nmdb private function clone public static function get class nmdb host,username,password return self instance 連線資料表 public function select db da...

用單例模式寫乙個php資料庫管理類

用慣了codeigniter框架,現在突然要自己用原生php開發,還真有點不習慣。因為介面開發過程中需要進行資料庫的操作。於是參考一些資料建立自己的 資料庫管理類 首先建立資料庫連線配置檔案 db.config.php 資料庫配置檔案 開發用資料庫 define db name order mysq...

php單例模式連線資料庫封裝類

單例模式有三大原則 建構函式不能為public 有乙個儲存例項的靜態成員變數 擁有訪問這個例項的公共靜態方法 基於單例模式的php資料庫連線類 class db static public function getinstance return self instance public functi...