[TOC]
* * * * *
## 1 文件
tp5的緩存驅動目錄thinkphp\library\think\db\driver\
tp5通過PDO封裝多種數據庫驅動。
包含以下**6種**
* * * * *
1 Mongo.php Mongo數據庫驅動
2 Mysql.php Mysql數據庫驅動
3 Oracle.php Oracle數據庫驅動
4 Pgsql.php Pgsql數據庫驅動
5 Sqlite.php Sqlite數據庫驅動
6 Sqlsrv.php Sqlsrv數據庫驅動
Driver.php 數據庫驅動基類
* * * * *
## 2 數據庫驅動
> 1 數據庫配置 convention.php和application\database.php
~~~
'database' => [
// 數據庫類型
'type' => 'mysql',
// 數據庫連接DSN配置
'dsn' => '',
// 服務器地址
'hostname' => 'localhost',
// 數據庫名
'database' => '',
// 數據庫用戶名
'username' => 'root',
// 數據庫密碼
'password' => '',
// 數據庫連接端口
'hostport' => '',
// 數據庫連接參數
'params' => [],
// 數據庫編碼默認采用utf8
'charset' => 'utf8',
// 數據庫表前綴
'prefix' => '',
// 數據庫調試模式
'debug' => false,
// 數據庫部署方式:0 集中式(單一服務器),1 分布式(主從服務器)
'deploy' => 0,
// 數據庫讀寫是否分離 主從式有效
'rw_separate' => false,
// 讀寫分離后 主服務器數量
'master_num' => 1,
// 指定從服務器序號
'slave_no' => '',
],
~~~
默認為mysql驅動
> 2 數據庫初始化 thinkphp\library\think\Db.php中的connect()
~~~
if (!isset(self::$instances[$md5])) {
$options = self::parseConfig($config);
if (empty($options['type'])) {
throw new Exception('db type error');
}
$class = (!empty($options['namespace']) ? $options['namespace'] : '\\think\\db\\driver\\') . ucwords($options['type']);
self::$instances[$md5] = new $class($options);
APP_DEBUG && Log::record('[ DB ] INIT ' . $options['type'] . ':' . var_export($options, true), 'info');
}
~~~
分析可知根據type選擇不同數據庫驅動進行初始化
## 3 數據庫驅動接口
> 1 Driver.php
1 構造函數
`public function __construct($config = ''){}`
2 連接與關閉
`public function connect($config = '', $linkNum = 0, $autoConnection = false){}`
`public function close(){}`
3 語句的執行
`public function query($sql, $bind = [], $fetch = false, $master = false){}`
`public function execute($sql, $bind = [], $fetch = false){}`
3 增刪改查
`public function insert($data, $options = [], $replace = false){}`
`public function select($options = []){}`
`public function update($data, $options){}`
`public function delete($options = []){}`
`public function updateFieldAll($field,$pk,$dataSet,$operator = '=',$options = []){}`
`public function insertAll($dataSet, $options = [], $replace = false){}`
`public function selectInsert($fields, $table, $options = []){}`
4 sql語句解析
`public function buildSelectSql($options = []){}`
`public function parseSql($sql, $options = []){}`
`public function quote($str){}`
`public function setModel($model){}`
5 事務操作
`public function startTrans(){}`
`public function commit(){}`
`public function rollback(){}`
6 操作結果查詢
`public function getQueryTimes($execute = false){}`
`public function getExecuteTimes(){}`
`public function getLastSql($model = ''){}`
`public function getLastInsID(){}`
`public function getError(){}`
`public function free(){}`
> 2 driver子類
1 獲取數據庫的數據表信息
`public function getTables($dbName = ''){}`
2 獲取數據表的字段
`public function getFields($tableName){}`
## 4 總結
1 數據庫配置
> convention.php databse.php
2 數據庫初始化
> Db::connect()
3 數據庫接口
> 數據庫的初始化與選項設置
> 數據庫的數據增刪改查
> 數據庫的系統信息,操作信息
- 更新記錄
- 概述
- 文件索引
- 函數索引
- 章節格式
- 框架流程
- 前:章節說明
- 主:(index.php)入口
- 主:(start.php)框架引導
- 主:(App.php)應用啟動
- 主:(App.php)應用調度
- C:(Controller.php)應用控制器
- M:(Model.php)數據模型
- V:(View.php)視圖對象
- 附:(App.php)應用啟動
- 附:(base.php)全局變量
- 附:(common.php)模式配置
- 附:(convention.php)全局配置
- 附:(Loader.php)自動加載器
- 附:(Build.php)自動生成
- 附:(Hook.php)監聽回調
- 附:(Route.php)全局路由
- 附:(Response.php)數據輸出
- 附:(Log.php)日志記錄
- 附:(Exception.php)異常處理
- 框架工具
- 另:(helper.php)輔助函數
- 另:(Cache.php)數據緩存
- 另:(Cookie.php)cookie操作
- 另:(Console.php)控制臺
- 另:(Debug.php)開發調試
- 另:(Error.php)錯誤處理
- 另:(Url.php)Url操作文件
- 另:(Loader.php)加載器實例化
- 另:(Input.php)數據輸入
- 另:(Lang.php)語言包管理
- 另:(ORM.php)ORM基類
- 另:(Process.php)進程管理
- 另:(Session.php)session操作
- 另:(Template.php)模板解析
- 框架驅動
- D:(\config)配置解析
- D:(\controller)控制器擴展
- D:(\model)模型擴展
- D:(\db)數據庫驅動
- D:(\view)模板解析
- D:(\template)模板標簽庫
- D:(\session)session驅動
- D:(\cache)緩存驅動
- D:(\console)控制臺
- D:(\process)進程擴展
- T:(\traits)Trait目錄
- D:(\exception)異常實現
- D:(\log)日志驅動
- 使用范例
- 服務器與框架的安裝
- 控制器操作
- 數據模型操作
- 視圖渲染控制
- MVC開發初探
- 模塊開發
- 入口文件定義全局變量
- 運行模式開發
- 框架配置
- 自動生成應用
- 事件與插件注冊
- 路由規則注冊
- 輸出控制
- 多種應用組織
- 綜合應用
- tp框架整合后臺auto架構快速開發
- 基礎原理
- php默認全局變量
- php的魔術方法
- php命名空間
- php的自動加載
- php的composer
- php的反射
- php的trait機制
- php設計模式
- php的系統時區
- php的異常錯誤
- php的輸出控制
- php的正則表達式
- php的閉包函數
- php的會話控制
- php的接口
- php的PDO
- php的字符串操作
- php的curl
- 框架心得
- 心:整體結構
- 心:配置詳解
- 心:加載器詳解
- 心:輸入輸出詳解
- 心:url路由詳解
- 心:模板詳解
- 心:模型詳解
- 心:日志詳解
- 心:緩存詳解
- 心:控制臺詳解
- 框架更新
- 4.20(驗證類,助手函數)
- 4.27(新模型Model功能)
- 5.4(新數據庫驅動)
- 7.28(自動加載)