热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Laravel关系和数据透视表

我正在开发我的第一个laravel应用,现在我正在为我的内容类型创建一些关系。

我正在开发我的第一个laravel应用,现在我正在为我的内容类型创建一些关系。

在应用程序中,我可以创建一个约会,该约会在执行过程中还将保存详细信息并创建一个新客户端。但是我希望我的用户能够看到其客户的“历史记录”,并查看他们已预订的所有约会。

到目前为止,我已经将hasMany关系添加到我的客户端模型,并且在约会模型中添加了hasOne逆。因此,到目前为止,我的想法是,一个客户可以有多个约会,而一个约会只能有一个客户。

但是...

我真的很难将两者连接在一起,因为理想情况下,我需要执行以下操作:-

对于X客户ID,获取所有与客户ID匹配的约会

在这种情况下,您将在哪里使用数据透视表进行管理?如果是这样,您在哪里放置逻辑以处理模型中ID的附加/取消附加?

或者我的呼叫中缺少某些内容,因为我的客户端模型中的约会函数只有以下内容:-

return $this->hasMany('App\Appointment');

我还需要通过其他什么吗?

我已经阅读了文档,而且毫无头绪,并且来自WP背景,因此任何帮助都很棒!


由于您在谈论a one-to-many relationship,因此不需要数据透视表。相反,您的appointments表应该有一个client_id列,该列链接到客户端。

要获得客户的所有约会,您只需要获取appointments属性(假设您的关系方法也称为appointments()

$appointments = $client->appointments;
// OR
$appointments = \App\Client::find($client_id)->appointments;

由于该属性在类中不存在,因此Laravel将查找具有相同名称的关系方法。找到后,Laravel将在约会表中查询具有该客户ID的条目,并将其返回in a Collection。

关系方法在存储新约会时也有帮助:

$client->appointments()->create(['date' => request('date'),...]);

由于Laravel知道这种关系,因此您无需在约会中手动添加client_id

您在命名方法/表列等方面具有一定的灵活性,但是我通常发现最好坚持使用the Laravel conventions。

,

尝试这种方法

//In your Appointment Model
class Appointment extends Model
{
public function client()
{
return $this->belongsTo('App\Client');
}
}
//In your Client Model
class Client extends Model
{
public function appointments()
{
return $this->hasMany('App\Appointment'); //if the foreign column in your appointments table is named different the client_id,the specify that column ('App\Appointment','id_of_client)
}
...
}
// query to fetch client's appointments
$client = Client::findOrFail(1)->with(['appointments']);

,

您可以在此处针对当前上下文使用一对多关系。

// Appointment model
class Appointment extends Model
{
...
/**
* Get the client associated with the Appointment.
*/
public function client()
{
return $this->hasOne('App\Client','client_id');
}
...
}
// client model
class Client extends Model
{
...
/**
* Get the Appointments associated with the client.
*/
public function appointments()
{
return $this->hasMany('App\Appointment');
}
...
}
// query to fetch client's appointments
Client::find(1)->with(['appointments']);

推荐阅读
  • 解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法
    本文介绍了解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法,包括检查location配置是否正确、pass_proxy是否需要加“/”等。同时,还介绍了修改nginx的error.log日志级别为debug,以便查看详细日志信息。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • 如何在HTML中获取鼠标的当前位置
    本文介绍了在HTML中获取鼠标当前位置的三种方法,分别是相对于屏幕的位置、相对于窗口的位置以及考虑了页面滚动因素的位置。通过这些方法可以准确获取鼠标的坐标信息。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 利用Visual Basic开发SAP接口程序初探的方法与原理
    本文介绍了利用Visual Basic开发SAP接口程序的方法与原理,以及SAP R/3系统的特点和二次开发平台ABAP的使用。通过程序接口自动读取SAP R/3的数据表或视图,在外部进行处理和利用水晶报表等工具生成符合中国人习惯的报表样式。具体介绍了RFC调用的原理和模型,并强调本文主要不讨论SAP R/3函数的开发,而是针对使用SAP的公司的非ABAP开发人员提供了初步的接口程序开发指导。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • centos安装Mysql的方法及步骤详解
    本文介绍了centos安装Mysql的两种方式:rpm方式和绿色方式安装,详细介绍了安装所需的软件包以及安装过程中的注意事项,包括检查是否安装成功的方法。通过本文,读者可以了解到在centos系统上如何正确安装Mysql。 ... [详细]
author-avatar
小么么和
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有