mysql事务处理问题

浏览:268 发布日期:2019/05/13
5.0.0 - 普通 - 未处理
$connect属性会对mysql事务属性有干扰。
情景是这样的:
database.php只有一个单一的数据库连接
<?php
return [
// 数据库类型
'type' => Env::get('database.type', 'mysql'),
// 服务器地址
'hostname' => Env::get('database.hostname', '127.0.0.1'),
// 数据库名
'database' => Env::get('database.database', 'laytp'),
// 用户名
'username' => Env::get('database.username', 'root'),
// 密码
'password' => Env::get('database.password', '123456'),
// 端口
'hostport' => Env::get('database.hostport', ''),
// 连接dsn
'dsn' => '',
// 数据库连接参数
'params' => [],
// 数据库编码默认采用utf8
'charset' => Env::get('database.charset', 'utf8'),
// 数据库表前缀
'prefix' => Env::get('database.prefix', 'lt_'),
// 数据库调试模式
'debug' => Env::get('database.debug', true),
// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
'deploy' => 0,
// 数据库读写是否分离 主从式有效
'rw_separate' => false,
// 读写分离后 主服务器数量
'master_num' => 1,
// 指定从服务器序号
'slave_no' => '',
// 自动读取主库数据
'read_master' => false,
// 是否严格检查字段是否存在
'fields_strict' => true,
// 数据集返回类型
'resultset_type' => 'array',
// 自动写入时间戳字段
'auto_timestamp' => 'datetime',
// 时间字段取出后的默认时间格式
'datetime_format' => 'Y-m-d H:i:s',
// 是否需要进行SQL性能分析
'sql_explain' => false,
// Builder类
'builder' => '',
// Query类
'query' => '\\think\\db\\Query',
// 是否需要断线重连
'break_reconnect' => false,
// 断线标识字符串
'break_match_str' => [],
];

现在test表只有两个字段id和name,Test模型值设置一个数据库连接属性

<?php

namespace app\admin\model;

use think\Model;

class Test extends Model
{
//数据库
protected $connection = 'database';
}

如下代码
<?php

Db:startTrans();
$test_model = model('test');
$test_model->insert(['name'=>1]);
//Db::commit();

事务不提交也会执行insert操作

如果不设置Test模型的connection属性,那么事务不提交就不会执行insert操作

BUG:使用的数据库连接信息都相同,只是设置和不设置模型的connection属性,却影响了mysql事务执行。
评论(
后面还有条评论,点击查看>>