0

0

说说Laravel模型关联关系最单纯的“一对一”!

藏色散人

藏色散人

发布时间:2020-10-12 14:10:34

|

3431人浏览过

|

来源于learnku

转载

下面由Laravel教程栏目给大家介绍Laravel模型关联关系最单纯的“一对一”! ,希望对需要的朋友有所帮助!

说说Laravel模型关联关系最单纯的“一对一”!

引言

关系型数据库提供了非常好用的数据关联绑定模式,使用SQL语句可以方便地进行关联数据查询和操作。

如果所有关联关系放到数据库层面操作,势必非常不便。

所以,laravel模型提供了关联关系,本文就来梳理梳理那些用法。

代码时间

我们不要PPT似的念稿子,罗列出所有的关系模型,那样不直观也不是高效学习的方式。

还是从示例触发,看看关联关系到底解决的是什么问题,以及如何使用。

首先是数据库的准备,假设有如下两个表的字段对应关系:

pic

使用命令行创建一个Profile模型,并同时创建迁移文件:

php artisan make:model Profile --migration

来看生成的 app/Profile.php 文件的内容:

namespace App;use Illuminate\Database\Eloquent\Model;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,所以这是一对一的关系,

点创DOidea网上书店
点创DOidea网上书店

一套专业的网上书店程序,可以作为新华书店及大中型书店网上销售的首选,满足在线支付及汇款确认机制。功能简介:图书分类、查询、排行、最新、特价、关注排行、销售排行,新闻系统、汇款确认机制、求购书籍、在线咨询、热门图书定义、全站广告后台管理、后台采用WEBEDIT编辑器、集成"支付宝"在线支付等...v3.5版特殊功能说明(前台):1.自带5种风格主题。2.友好的页面提示(对网站全部

下载

在User模型里添加如下声明:

class User extends Model {
    public function profile()
    {
        return $this->hasOne('App\Profile');
    }}

一旦定义了上述方法,就可以这样链式调用了:

$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模型关联的最简单的“一对一”,我们从程序角度和数据库角度讲解了

如何在删除资源时的一致性删除。更复杂的关系,在编程层面是有意义的,我们下一章介绍更多的关联关系。                                   

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2679

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1660

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1517

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1419

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1488

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

12

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Laravel---API接口
Laravel---API接口

共7课时 | 0.6万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号