mysql事務處理問題

瀏覽:220 發布日期: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事務執行。
評論(
后面還有條評論,點擊查看>>
至尊炸金花百人场规律 如何玩pc稳赚不赔 大乐透基本走势图 双面盘彩票下载 双色球就机选投注号码 水晶宫 欢乐生肖开奖结果 重庆时时开彩结果官网 极速时时网站是多少 重庆时时彩单双走势 北京pk10十码刷水 排列三组选六投注方案 四川时时是真的吗 派彩网电子走势图 彩票计划软件怎么开发的 二八杠生死门详细讲解