在 Laravel 12 中使用 华为 GaussDB(兼容 PostgreSQL 协议)作为数据库,可以通过以下步骤配置和操作。GaussDB 基于 PostgreSQL 生态,因此 Laravel 的 PostgreSQL 驱动(pgsql
)可直接适配。
1. 安装依赖
确保 Laravel 项目已包含 PostgreSQL 驱动(默认已集成):
composer require laravel/framework
2. 配置数据库连接
修改 Laravel 的 .env
文件,配置 GaussDB 连接参数:
DB_CONNECTION=pgsql
DB_HOST=your_gaussdb_host # GaussDB 服务器地址
DB_PORT=5432 # 默认端口(根据实际修改)
DB_DATABASE=your_database # 数据库名
DB_USERNAME=your_username # 用户名
DB_PASSWORD=your_password # 密码
在 config/database.php
中检查 pgsql
配置项是否与 .env
一致。
3. 测试连接
使用 Laravel 的数据库命令行工具测试连接:
php artisan db:show
或执行原生 SQL 测试:
php artisan tinker
>>> DB::select('SELECT version()');
4. 使用迁移与模型
创建迁移文件
php artisan make:migration create_users_table
编辑迁移文件(如 database/migrations/xxxx_create_users_table.php
):
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration {
public function up()
{
Schema::create('users', function (Blueprint $table) {
$table->id();
$table->string('name');
$table->string('email')->unique();
$table->timestamps();
});
}
public function down()
{
Schema::dropIfExists('users');
}
};
执行迁移:
php artisan migrate
创建模型
php artisan make:model User
模型会自动关联 GaussDB 中的 users
表。
5. 注意事项
兼容性问题
- 数据类型:GaussDB 兼容 PostgreSQL,但部分高级特性(如自定义类型)可能需要调整。
- 扩展支持:如需使用 GaussDB 特有功能(如分布式事务),需通过原生 SQL 调用:
DB::statement("SELECT gaussdb_distributed_execute('...')");
性能优化
- 连接池:GaussDB 建议使用连接池(如配置
pgbouncer
),可在 Laravel 中通过DB::connection()->getPdo()->setAttribute(...)
调整参数。 - 索引:为高频查询字段添加索引:
$table->index('email');
备份与监控
- 使用 Laravel 任务调度备份数据库:
// app/Console/Kernel.php $schedule->command('db:backup')->daily();
- 集成 GaussDB 的监控工具(如华为云 DAS)观察性能。
6. 扩展:使用 Scout 全文搜索
如果需要在 GaussDB 中实现全文搜索,可结合 Laravel Scout 和 PostgreSQL 的 tsvector
类型:
// 在模型中启用 Scout
use Laravel\Scout\Searchable;
class User extends Model
{
use Searchable;
public function toSearchableArray()
{
return ['name' => $this->name];
}
}
配置 Scout 使用 database
驱动:
composer require laravel/scout
总结
Laravel 12 通过 pgsql
驱动可无缝对接 GaussDB,只需注意:
- 确保网络连通性和权限配置正确。
- 复杂场景下可能需要原生 SQL 或扩展包支持。
- 性能敏感型应用建议结合 GaussDB 的分布式特性优化。