关于⼆次开发,在laravel-admin框架中接⼊mongodb与mysql达成模型间关。。
。
序⾔:
项⽬前期使⽤mysql数据库,后期数据量增⼤,需要将mysql部分表迁移⾄mongodb,需要对应修改该表所对应的关联关系。
使⽤mongodb模块: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 $connection = 'mysql';
3. mysql模型切换到mongodb模型,需确定主键id的设定,经过我测试,需要设定mongodb的_id字段为主键,默认不设置就可以了。
4. 如果以前在mysql使⽤belongsTo模型进⾏关联的时,切换到mongodb,需要进⾏修改。
实例:mongodb模型(Dynamic) 待关联模型(User)
5. 如果在grid,laravel-admin 使⽤原有的关联关系在display默认链接将⽆法获取到数据,需要这么做:
$grid->model()->with('user');
6. 从mysql模型更换到mongodb模型有关的查询,也需要对应更改查询⽅式
例如:Dynamic::find($id) 需要改为: Dynamic::where('id',$id);
在上述情况下,find将⽆法查询到数据,where却可以查询到,特性是引⼊mongodb需要使⽤Eloquent 查询,另外可以使⽤原⽣写法:
DB::collection('books')->where('name', 'Hunger Games')->first();
7. 另外,原本与mysql模型关联的id,切换到了mongodb的_id,如果与其他客户端有冲突,需要在
关联表内进⾏mongodb的_id的存储,另外操作grid和form都以_id为主键,操作完之后,需要将
mongodb和mysql结合mysql原本的id与mongodb的_id进⾏对应,避免出现与其他客户端的冲突。
8. 多对多关联的⽅法,需要在被关联的表内创建存储mongodb的_id的字段,来与这个字段进⾏关联。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论