Yii2中事务的使用

官方是这样的

复制代码
复制代码
// $connection其实是数据库连接
$transaction = $connection->beginTransaction(); try { $connection->createCommand($sql1)->execute(); $connection->createCommand($sql2)->execute(); // ... executing other SQL statements ... $transaction->commit(); } catch (Exception $e) { $transaction->rollBack(); }
复制代码

其实可以这样使用

复制代码
$transaction = Yii::$app->db->beginTransaction();
try {
    // ... executing other SQL statements ...
    $transaction->commit();
} catch (\Exception $e) {
    $transaction->rollBack();
}

 

原因)创建数据库连接(Creating DB Connections)

想要访问数据库,你首先需要通过创建一个 yii\db\Connection 实例来与之建立连接。

复制代码
$db = new yii\db\Connection([
    'dsn' => 'mysql:host=localhost;dbname=example',
    'username' => 'root',
    'password' => '',
    'charset' => 'utf8',
]);

因为数据库连接经常需要在多个地方使用到, 一个常见的做法是以应用组件的方式来配置它,如下:

复制代码
复制代码
return [
    // ...
    'components' => [
        // ...
        'db' => [
            'class' => 'yii\db\Connection',
            'dsn' => 'mysql:host=localhost;dbname=example',
            'username' => 'root',
            'password' => '',
            'charset' => 'utf8',
        ],
    ],
    // ...
];
复制代码

之后你就可以通过语句 Yii::$app->db 来使用数据库连接了。

 

对于隔离级别,yii\db\Transaction 也提前定义了几个常量:

复制代码
const READ_UNCOMMITTED = 'READ UNCOMMITTED';    // 读未提交
const READ_COMMITTED = 'READ COMMITTED';      //  读提交
const REPEATABLE_READ = 'REPEATABLE READ';     //  可重复读
const SERIALIZABLE = 'SERIALIZABLE';        // 串行化

可以直接使用

复制代码
// 开启事务 隔离级别 串行化
$transaction = Yii::$app->db->beginTransaction( yii\db\Transaction::SERIALIZABLE);
复制代码

MySQL 事务隔离级别
忘了的可以看看这个

MySQL事务是不支持嵌套的,但是Yii2框架使用了缓存,可以使用事务嵌套,同学们可以打开下面链接看看
深入理解Yii2.0之事务(Transaction)
posted @   牛奔  阅读(5591)  评论(1编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示