91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP框架如何實現一個mysql數據庫封裝

發布時間:2021-08-27 10:54:35 來源:億速云 閱讀:196 作者:小新 欄目:開發技術

小編給大家分享一下PHP框架如何實現一個mysql數據庫封裝,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

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

1.使用方便性

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

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

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

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

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

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

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

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

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

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

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

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支持事務

Dba::beginTransaction();
Dba::commit();
Dba::rollBack();

3. 長時間運行

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

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

以上是“PHP框架如何實現一個mysql數據庫封裝”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

姜堰市| 榆树市| 格尔木市| 顺义区| 佳木斯市| 贺州市| 黎川县| 明水县| 台安县| 鸡泽县| 渝北区| 北碚区| 临湘市| 虹口区| 贡嘎县| 青田县| 江达县| 梨树县| 胶州市| 东乡族自治县| 铜山县| 子长县| 石家庄市| 民权县| 广南县| 北宁市| 定襄县| 额济纳旗| 漳州市| 安溪县| 长乐市| 滁州市| 武汉市| 新沂市| 兴海县| 宝坻区| 大荔县| 天长市| 轮台县| 武穴市| 塔城市|