使用方便性
采用直接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 3Dba::beginTransaction();
Dba::commit();
Dba::rollBack();
3. 長時間運行
在一些需要長時間運行的場景如swoole服務,後台worker等,可能會出現數據庫連接超時的情況。
當發現數據庫連接超時,dba將會自動嘗試重連。