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

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

 

 

  1. 使用方便性php

採用直接sql語句操做方式。只要會寫sql語句,那麼將沒有其餘學習成本。mysql

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

 

使用前須要顯示初始化並鏈接到數據庫嗎,固然不須要。數據庫

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

dba將會在合適的時機去鏈接數據庫並執行初始化字符編碼操做。php框架

 

查詢語句。不須要new一個查詢構造器也不提供鏈式操做方式,那樣複雜且低效。安全

dba提供瞭如下的查詢輔助函數。swoole

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將會自動嘗試重連。

相關文章
相關標籤/搜索