程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 如何實現一個php框架系列文章【6】mysql數據庫,

如何實現一個php框架系列文章【6】mysql數據庫,

編輯:關於PHP編程

如何實現一個php框架系列文章【6】mysql數據庫,


實現一個mysql數據庫封裝需要考慮的問題

 

 

  1. 使用方便性

采用直接sql語句操作方式。只要會寫sql語句,那麼將沒有其他學習成本。

uctphp框架提供的dba輔助封裝類,用會之後將愛不釋手。

 

使用前需要顯示初始化並連接到數據庫嗎,當然不需要。

直到執行第一條sql語句之前,都不會去連接數據庫,甚至不會new一個db對象。

dba將會在合適的時機去連接數據庫並執行初始化字符編碼操作。

 

查詢語句。不需要new一個查詢構造器也不提供鏈式操作方式,那樣復雜且低效。

dba提供了以下的查詢輔助函數。

1 2 3 4 5 6 7 8 9 10 11 12 //讀一個值 Dba::readOne($sql); //讀一行 Dba::readRowAssoc($sql); //讀所有行 Dba::readAllAssoc($sql); //讀所有行的第一列 Dba::readAllOne($sql);   //在實際業務場景中,經常會有分頁讀取部分數據的情況。 //只要一個函數即可返回指定頁碼的數據內容和數據總條數 Dba::readCountAndLimit($sql$page$limit);

ps:以上部分函數可以提供一個map函數對返回數組的每一行進行加工處理。

 

寫語句。為什麼要區分read和write呢,顯然可以擴展做到控制讀寫分離,雙寫等功能。

在有各種雲數據庫和數據庫中間件的今天,在數據庫層實現是更好的選擇。

 

 

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 Dba::write($sql);   /* 直接插入或更新kv形式的array數組 會自動對value進行轉義,也支持array類型的值。   如果自己寫sql語句要注意使用addslashes或mysql_real_escape_string來保證安全 */ Dba::insert($table$insert);     Dba::update($table$update$where);   /*     對批量插入數據有更高的效率     當然過多的行數應該用array_chunk來分批插入。 */ Dba::insertS($table$inserts);

 

2. 事務

使用pdo支持事務

1 2 3 Dba::beginTransaction(); Dba::commit(); Dba::rollBack();

 

3. 長時間運行

在一些需要長時間運行的場景如swoole服務,後台worker等,可能會出現數據庫連接超時的情況。

當發現數據庫連接超時,dba將會自動嘗試重連。

 

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved