ThinkPHP 5.0 数据库

ThinkPHP5.0数据库

一.数据库配置

在appliation/database.php中配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
<?php
// +----------------------------------------------------------------------
// | ThinkPHP [ WE CAN DO IT JUST THINK ]
// +----------------------------------------------------------------------
// | Copyright (c) 2006~2016 http://thinkphp.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: liu21st <liu21st@gmail.com>
// +----------------------------------------------------------------------

return [
// 数据库类型
'type' => 'mysql',
// 服务器地址
'hostname' => '127.0.0.1',
// 数据库名
'database' => '',
// 用户名
'username' => 'root',
// 密码
'password' => '',
// 端口
'hostport' => '',
// 连接dsn
'dsn' => '',
// 数据库连接参数
'params' => [],
// 数据库编码默认采用utf8
'charset' => 'utf8',
// 数据库表前缀
'prefix' => '',
// 数据库调试模式
'debug' => true,
// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
'deploy' => 0,
// 数据库读写是否分离 主从式有效
'rw_separate' => false,
// 读写分离后 主服务器数量
'master_num' => 1,
// 指定从服务器序号
'slave_no' => '',
// 是否严格检查字段是否存在
'fields_strict' => true,
// 数据集返回类型
'resultset_type' => 'array',
// 自动写入时间戳字段
'auto_timestamp' => false,
// 时间字段取出后的默认时间格式
'datetime_format' => 'Y-m-d H:i:s',
// 是否需要进行SQL性能分析
'sql_explain' => false,
];

二.原生sql语句

1
2
3
4
5
6
7
8
//插入记录
$result = Db::execute('insert into tp_data (id,name) values (1,"zhayt")');
//更新记录
$result = Db::execute('update tp_data set name = "Zhang" where id = 1');
//查询数据
$result = Db::query('select * from tp_data where id=1');
//删除数据
$result = Db::execute('delete from tp_data where id=1');

三.参数绑定、命名占位符绑定

1.参数绑定

1
2
3
//问号为占位符,后面的参数一一对应替代
$result = Db::execute('insert into tp_data (id,name) values (?,?),[1,'zhyat']');
//等价于 $result = Db::execute('insert into tp_data (id,name) values (1,"zhyat")');

2.命名占位符绑定

1
Db:execute('insert into tp_data (id,name) values (:id, :name)',['id'=>1,'name'=>'zhyat']);

四.多个数据库切换查询操作

1.在application/config.php配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
'db1' => [
// 数据库类型
'type' => 'mysql',
// 服务器地址
'hostname' => '127.0.0.1',
// 数据库名
'database' => 'tp_db1',
// 用户名
'username' => 'root',
// 密码
'password' => '',
// 端口
'hostport' => '',
// 数据库连接参数
'params' => [],
// 数据库编码默认采用utf8
'charset' => 'utf8',
// 数据库表前缀
'prefix' => 'tp_',
],
'db2' => [
// 数据库类型
'type' => 'mysql',
// 服务器地址
'hostname' => '127.0.0.1',
// 数据库名
'database' => 'tp_db2',
// 用户名
'username' => 'root',
// 密码
'password' => '',
// 端口
'hostport' => '',
// 数据库连接参数
'params' => [],
// 数据库编码默认采用utf8
'charset' => 'utf8',
// 数据库表前缀
'prefix' => 'tp_',
],

2.使用方法

1
2
$result = Db::connect(db1)->query('select * from tp_data where id=1');
$result = Db::connect(db2)->query('select * from tp_data where id=1');

五.查询构造器

ThinkPHP5.0中提供了查询构造器,基于PDO实现,使用了PDO参数绑定,传入的参数不需要额外的转义特殊字符

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
//插入记录
Db::table('tp_data')->insert(['id'=>1,'name'=>'zhyat']);
//等效上一条,会自动去config.php寻找前缀,更推荐使用这种
Db::name('data')->insert(['id'=>1,'name'=>'zhyat']);
//更新记录
Db::table('tp_data')
->where('id',1)
->updata(['name'=>zhyat]);
//查询数据
$list=Db::table('tp_data')
->where('id',1)
->select();
//删除数据
Db::table('tp_data')
->where('id',1)
->delete();

六.DB链式操作

1
2
3
4
5
6
7
8
//查询方法和CURD都可以使用连贯操作
//链式操作的结果不会带入后面的其它查询
//顺序可以变动
Db::table('think_user')
->where('status',1)
->order('create_time')
->limit(10)
->select();//select方法必须放到最后,因为其不是链式操作方法

七.事物支持

1.什么是事物

几个操作同步进行,要不全部成功,要不就全部撤销,这几个操作组合称为事务

2.要在Mysql数据库中设置表类型为InnoDB

3.自动:

1
2
3
4
Db:transaction(function(){
Db::name(data)->delete(1);
Db::name(data)->insert(['id'=>2,'name'=>'zhyat']);
);

4.手动:

1
2
3
4
5
6
7
8
9
10
11
//启动事务
Db::startTrans();
try{
Db::table('tp_data')->detele(1);
Db::name(data)->insert(['id'=>2,'name'=>'zhyat']);
//提交事务
Db:commit();
} catch(\Exception $e){
//回滚事务
Db::rollback();
}