[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(自动加载)