- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在运行 laravel 5.4
并注意到事务中的回滚不起作用。我在 settings.php
文件中将我的数据库引擎设置为 InnoDB
并尝试了 DB::rollback();
和 DB::rollBack();
(即大写和小写 b)但它不会回滚我的数据库。
我在下面写了一个单元测试。它创建一条记录,提交它,然后回滚。但是,最后一个断言失败了。回滚后,数据库中仍然有记录。有什么我想念的吗?还是 laravel 存在错误?
public function testRollback()
{
$this->artisan('migrate:refresh', [
'--seed' => '1'
]);
DB::beginTransaction();
Season::create(['start_date' => Carbon::now(), 'end_date' => Carbon::now(),]);
DB::commit();
$this->assertDatabaseHas('seasons', [
'start_date' => Carbon::now(), 'end_date' => Carbon::now(),
]);
DB::rollBack();
// This assertion fails. It still finds the record after calling roll back
$this->assertDatabaseMissing('seasons', [
'start_date' => Carbon::now(), 'end_date' => Carbon::now(),
]);
}
最佳答案
交易包括三个步骤:
你用 DB::beginTransaction
或 MySQL 等效的 BEGIN TRANSACTION
启动它,然后你执行你需要的命令,然后(这是重要的部分)你 < strong>或者 COMMIT
或者 ROLLBACK
但是,一旦您提交了事务,就无法再将其回滚。
将测试更改为:
public function testRollback()
{
$this->artisan('migrate:refresh', [
'--seed' => '1'
]);
DB::beginTransaction();
Season::create(['start_date' => Carbon::now(), 'end_date' => Carbon::now(),]);
$this->assertDatabaseHas('seasons', [
'start_date' => Carbon::now(), 'end_date' => Carbon::now(),
]);
DB::rollback();
$this->assertDatabaseMissing('seasons', [
'start_date' => Carbon::now(), 'end_date' => Carbon::now(),
]);
}
这应该有效,因为在事务回滚之前,数据库“认为”记录在那里。
在实践中使用事务时,您希望使用 the docs 中的建议,例如:
DB::transaction(function()
{
DB::table('users')->update(array('votes' => 1));
DB::table('posts')->delete();
});
这将确保包装操作的原子性,并在函数体内抛出异常时回滚(如果需要,您也可以抛出自己作为中止的一种方式)。
关于php - Laravel 事务回滚似乎不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46617452/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!