这篇文章主要介绍了关于Laravel之Eloquent ORM ,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下
一、ORM编程思想
1.1 Active Record 设计模式
Active Record
是一种数据访问设计模式,它可以帮助你实现数据对象Object
到关系数据库的映射。应用Active Record
时,每一个类的实例对象唯一对应一个数据库表的一行(一对一关系)。你只需继承一个abstract Active Record
类就可以使用该本文@来#源gaodai$ma#com搞$$代**码网搞代gaodaima码设计模式访问数据库,其最大的好处是使用非常简单
1.2 调试工具 Laravel Debugbar
https://github.com/barryvdh/l…
Installation:
composer require barryvdh/laravel-debugbar --dev
二、一对一关系映射
2.1 创建表
public function up() { Schema::create('profiles', function (Blueprint $table) { $table->increments('id'); $table->string('phone'); $table->unsignedInteger('user_id'); //显示的声明外键:通知数据库根据外键关联表和建立索引,提高运行速度 $table->foreign('user_id') ->references('id') ->on('users') ->onDelete('cascade'); $table->timestamps(); }); }
2.2 创建模型关系
2.2.1 正向关系绑定
public function profile(){ return $this->hasOne(Profile::class);}
2.2.2 反向关系绑定
public function user(){ return $this->belongsTo(User::class);}
2.3 外键
自定义外键:
return $this->hasOne(Profile::class,'显示指定自定义外键');
2.4 一对一测试
依赖注入Request $request
,获取当前登录用户$request->user()
Route::get('/test',function (Request $request){ //反向// $profile = \App\Profile::find(1);// dd($profile->user); $user = $request->user();// if (is_null($user->profile)){// $user->profile()->create([// 'phone' => '15801340269'// ]);// } //用firstOrCreate改进if $user->profile()->firstOrCreate(['user_id' => $user->id],[ 'phone' => '18363046291' ]); //访问属性一样访问方法 dd($user->profile);});
三、一对多关系映射
1:N hasMany(XXX:class) 反之:belongsTo(XXX:class)