Laravel 下的跨库事务操作是基于连接的 当执行 DB::beginTransaction(); 的时候 其实是和默认的数据库配置建立了连接 后面的操作 commit 或者 rollback 都是操作的这个默认数据库 如果在这中间操作了其他的数据库 对他是不生效的
解决方案
开始事务的时候就指定连接
同时 commit 和 rollback 都 指定连接
增加多数据库配置
在配置目录 config/database.php 文件中的 connections 数组下 增加多数据库连接配置
'mysql' => [
'driver' => 'mysql',
'host' => env('DB_HOST', '127.0.0.1'),
'port' => env('DB_PORT', '3306'),
'database' => env('DB_DATABASE', 'forge'),
'username' => env('DB_USERNAME', 'forge'),
'password' => env('DB_PASSWORD', ''),
'unix_socket' => env('DB_SOCKET', ''),
'charset' => 'utf8mb4',
'collation' => 'utf8mb4_unicode_ci',
'prefix' => env('DB_PREFIX', ''),
'strict' => true,
'engine' => null,
],
//增加test数据库配置
'test' => [
'driver' => 'mysql',
'host' => env('DB_TEST_HOST', '127.0.0.1'),
'port' => env('DB_TEST_PORT', '3306'),
'database' => env('DB_TEST_DATABASE', 'forge'),
'username' => env('DB_TEST_USERNAME', 'forge'),
'password' => env('DB_TEST_PASSWORD', ''),
'unix_socket' => env('DB_TEST_SOCKET', ''),
'charset' => 'utf8mb4',
'collation' => 'utf8mb4_unicode_ci',
'prefix' => env('DB_TEST_PREFIX', ''),
'strict' => true,
'engine' => null,
],
给Model指定数据库连接
新建一个test数据库的连接基类
指定连接为上面配置的连接别名
use Illuminate\Database\Eloquent\Model;
class BaseModel extends Model
{
protected $connection = "test";
}
跨库事务操作
try {
//开启默认数据库的事务
DB::beginTransaction();
//开启test数据库的事务
DB::connection('test')->beginTransaction();
//中间各种数据库操作
Table1::xxxxxx();
Table2::xxxxxx();
if (true) {
//一起提交
DB::commit();
DB::connection('test')->commit();
} else {
//一起回滚
DB::rollback();
DB::connection('test')->rollback();
}
} catch (\Exception $exception) {
echo "catch some errors:".$exception->getMessage();
}