关于二次开发,在laravel-admin框架中接入mongodb与mysql达成模型间关联关系的方法。

本文介绍了在laravel-admin框架下,如何处理mysql迁移到mongodb后,模型间的关联关系。通过使用jenssegers/laravel-mongodb模块,调整模型配置,解决连接错误,设置主键,并调整belongsTo关联关系以适配mongodb。同时,文章提到了查询方式的改变,以及在多对多关联中处理_id字段以避免冲突。
摘要由CSDN通过智能技术生成

序言:
项目前期使用mysql数据库,后期数据量增大,需要将mysql部分表迁移至mongodb,需要对应修改该表所对应的关联关系。

使用mongodb模块:jenssegers/laravel-mongodb
GitHub地址:jenssegers/laravel-mongodb的Github链接

  1. mongodb模型引入jenssegers/laravel-mongodb,并重写boot方法,并设定链接方式和链接集合:

    use Jenssegers\Mongodb\Eloquent\Model as Eloquent;
    protected $connection = 'mongodb'; //链接方式
    protected $collection = 'list'; //链接集合
        
    重写boot方法:
       protected static function boot()
       {
           static::saving(function(Eloquent $model){
               unset($model->user_name);
           });
           parent::boot();
       }
    
  2. mysql模型需要设置链接类型、引入HybridRelations,如果不设置会出现connection链接错误的问题:

    use Jenssegers\Mongodb\Eloquent\HybridRelations;   //引入HybridRelations
    use HybridRelations; //所有与mongodb有关联的模型 都需要引入HybridRelations
    protected $co
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值