3分钟短文:说说Laravel模型关联关系最单纯的“一对一”
引言
关系型数据库提供了非常好用的数据关联绑定模式,使用SQL语句可以方便地进行关联数据查询和操作。
如果所有关联关系放到数据库层面操作,势必非常不便。
所以,laravel模型提供了关联关系,本文就来梳理梳理那些用法。
代码时间
我们不要PPT似的念稿子,罗列出所有的关系模型,那样不直观也不是高效学习的方式。
还是从示例触发,看看关联关系到底解决的是什么问题,以及如何使用。
首先是数据库的准备,假设有如下两个表的字段对应关系:
使用命令行创建一个Profile模型,并同时创建迁移文件:
php artisan make:model Profile --migration
来看生成的 app/Profile.php 文件的内容:
namespace App;
use IlluminateDatabaseEloquentModel;
class Profile extends Model {}
因为使用了 --migration 选项,laravel自动生成了 database/migrations/2020_10_11_015236_create_profiles_table.php 文件,
用于生成对应的数据库 profiles 表。
还是老规矩,先实现数据库迁移使用的 up 方法:
public function up()
{
Schema::create('profiles', function(Blueprint $table)
{
$table->increments('id');
$table->integer('user_id')->unsigned();
$table->foreign('user_id')->references('id')->on('users');
$table->string('url');
$table->string('telephone');
$table->timestamps();
});
}
用于回滚的方法就不列出来了,仅仅是表的删除。下面手动执行迁移指令:
php artisan migrate
输出内容如下:
Migrated: 2020_10_11_015236_create_profiles_table.php
关联关系
一切准备就绪,我们开始使用关联关系来处理数据的一致性。一个user对应一个profile,所以这是一对一的关系,
在User模型里添加如下声明:
class User extends Model {
public function profile()
{
return $this->hasOne('AppProfile');
}
}
一旦定义了上述方法,就可以这样链式调用了:
$user = User::find(1)->profile->telephone;
我们拆解开做解释。首先使用 User::find($id) 返回的是一个 User 模型对象的实例。
该实例有一个 profile 方法,就是上面这段关系声明。
调用 profile 返回的是一个 Profile 对象的实例,所以可以继续调用Profile的属性,也就是 telephone 的由来了。
需要特别注意的是,类似下面的写法,返回结果是不同的:
$user = User::find($id);
$user->profile; // 返回 Profile 对象
$user->profile(); // 返回 hasOne 关联关系对象
大家在使用的时候,一定不要迷惑,要分清楚使用方法。
有了关联查询,自然就有关联更新,用法如下:
$profile = new Profile;
$profile->telephone = '12345678';
$user = User::find(1);
$user->profile()->save($profile);
有了关联更新这种写操作,自然就有了关联删除,模型方法的调用而已:
$user = User::find($id);
$user->profile()->delete();
由于是严格一对一的关系,也就是一个user只有一个profile,如果某个user被删除了,
就会剩下一个孤零零的profile无所依附。
除了在程序上下文的一致性保证外,还可以使用数据库的外键,在删除user时将profile关联删除。那么只要修改迁移文件,
并添加如下内容:
$table->integer('user_id')->unsigned();
$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
写在最后
本文介绍了laravel模型关联的最简单的“一对一”,我们从程序角度和数据库角度讲解了
如何在删除资源时的一致性删除。更复杂的关系,在编程层面是有意义的,我们下一章介绍更多的关联关系。
Happy coding :-)
我是@程序员小助手,专注编程知识,圈子动态的IT领域原创作者
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC
- R语言ggmap空间可视化机动车交通事故地图
- 基于matlab的Lorenz系统仿真可视化
- 使用R语言对进行空间数据可视化
- R语言中基于混合数据抽样(MIDAS)回归的HAR-RV模型预测GDP增长
- R语言马尔可夫体制转换模型Markov regime switching
- Python中的ARIMA模型、SARIMA模型和SARIMAX模型对时间序列预测
- python3用ARIMA模型进行时间序列预测
- R语言马尔可夫转换模型研究交通伤亡人数事故预测
- scrapy爬虫框架和selenium的使用:对优惠券推荐网站数据LDA文本挖掘
- 使用R语言进行Metroplis-in-Gibbs采样和MCMC运行分析
- R语言中的马尔科夫机制转换(Markov regime switching)模型
- R语言ARMA-EGARCH模型、集成预测算法对SPX实际波动率进行预测
- nginx快速入门
- R语言中进行期权定价的Heston模型
- 使用R语言随机波动模型SV处理时间序列中的随机波动率