## Mix\Database\Database::class
基于 PDO 封裝的數據庫組件,內置連接池,可獨立使用。
## 組件
使用 [composer]([https://www.phpcomposer.com/](https://www.phpcomposer.com/)) 安裝:
~~~
composer require mix/database
~~~
## 依賴注入配置
- [manifest/beans/database.php](https://github.com/mix-php/mix-skeleton/blob/master/manifest/beans/database.php)
> \>= v2.2.9 新增了 maxLifetime、waitTimeout 參數
## 長連接超時問題
MySQL 配置文件內的 `interactive_timeout` 與 `wait_timeout` 參數,決定了 sleep 多長時間的連接會被主動 kill,正常情況下是需要用戶自己來處理連接超時的問題,但使用該組件時用戶不需要處理,組件底層已經幫你處理了。
- `maxLifetime` 連接因閑置被 mysql 主動 kill 連接時,連接會被重連,業務不受影響,但調度器依然還是會調度一個異常,如果想消除這個異常,配置該參數 < `interactive_timeout` 與 `wait_timeout` 參數。
## 獲取連接
- 直接調用方法獲取連接
>[danger] 注意:$conn 必須立即置空歸還
```
/** @var \Mix\Database\Database $db */
$db = context()->get('database');
// 調用方法返回連接,然后執行
$conn = $db->prepare("SELECT * FROM `post`");
$result = $conn->queryAll();
$affectedRows = $conn->getRowCount();
$conn = null; // 使用完后立即手動歸還連接,避免出現協程死鎖
// 不需要獲取 getRowCount、getLastInsertId 時,直接調用
$result = $db->prepare("SELECT * FROM `post`")->queryAll();
```
- 手動獲取連接
>[danger] 注意:每次 borrow 取出后用完必須立即置空歸還,并且在這個連接的使用過程中不可再次獲取其他連接
```
/** @var \Mix\Database\Database $db */
$db = context()->get('database');
$conn = $db->borrow();
// ...
$conn = null; // 使用完后立即手動歸還連接,避免出現協程死鎖
```
當出現以下異常信息,很有可能就是協程死鎖導致
~~~
PHP Fatal error: Swoole\Coroutine\Channel::close(): you must call Channel constructor first in /Users/***/worker-pool/src/AbstractWorker.php on line 96
Fatal error: Swoole\Coroutine\Channel::close(): you must call Channel constructor first in /Users/***/worker-pool/src/AbstractWorker.php on line 96
[2020-10-26 19:48:59 @61837.0] WARNING ~Channel (ERRNO 10003): channel is destroyed, 1 consumers will be discarded
[2020-10-26 19:48:59 @61837.0] WARNING ~Channel (ERRNO 10003): channel is destroyed, 20 consumers will be discarded
[2020-10-26 19:48:59 @61837.0] WARNING ~Channel (ERRNO 10003): channel is destroyed, 1 consumers will be discarded
[2020-10-26 19:48:59 @61837.0] WARNING ~Channel (ERRNO 10003): channel is destroyed, 1 consumers will be discarded
~~~
- 獲取查詢構造器
```
/** @var \Mix\Database\Database $db */
$db = context()->get('database');
$builder = $db->table('user');
```
- 歡迎使用 MixPHP
- 安裝說明
- 全棧開發
- 微服務開發
- Phar 開發
- 如何部署
- 獨立部署
- Nginx
- Supervisord
- 新手教程
- 命令行常識
- 進程管理
- 熱更新
- 全局變量
- 調試程序
- 入門須知
- 命名空間
- 自動加載
- 入口文件
- 增改應用
- 自動補全 IDE
- 核心功能
- 配置 (manifest.php)
- 依賴注入
- 事件調度
- 驗證器
- 驗證器定義
- 驗證規則
- 靜態調用
- 日志 Monolog
- 緩存
- 協程
- 什么是協程
- 開啟協程
- Runtime
- 簡介
- 創建協程 xgo + Channel
- 創建協程 xgo + WaitGroup
- xgo
- xdefer
- Channel
- WaitGroup
- Timer + Ticker
- Signal
- Select
- Context
- WorkerPool
- 數據庫
- Database
- Database
- Connection
- QueryBuilder
- ExecutedEvent
- Redis
- Redis
- Connection
- CalledEvent
- 命令行
- 簡介
- Application
- 創建命令
- 命令參數
- 打印與顏色
- 守護進程
- 后臺運行
- Web/API 應用
- 簡介
- 編寫一個接口
- 服務器
- 路由 FastRoute
- 中間件
- 請求
- 響應
- 文件上傳
- 控制器
- 視圖
- Auth
- Session
- Guzzle
- HTTP 404/500
- 安全建議
- WebSocket 應用
- 簡介
- 服務器
- 客戶端
- Client
- JavaScript
- Swoole
- nginx代理
- 60s無消息斷線
- Micro 微服務
- 簡介
- 編寫一個微服務
- Mix Micro
- Go Micro
- gRPC
- JSON-RPC
- 服務注冊
- 配置中心
- 熔斷與降級
- 調用鏈追蹤
- 服務限流
- Sync Invoke 同步調用
- 簡介
- 服務器
- 客戶端
- TCP 應用
- 簡介
- 服務器
- 客戶端
- Telnet
- PHP
- Swoole
- UDP 應用
- 簡介
- 服務器
- 客戶端
- NC
- Swoole
- 第三方接入
- EasyWeChat
- Sentry
- Doctrine Cache
- 常見問題
- 如何利用 CPU 多核
- 連接多個數據庫
- 如何設置跨域
- form-data 上傳文件失敗
- 輸出大于 2M 的文件失敗