首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

浅谈laravel5.5 belongsToMany自身正确用法

场景 用户之间相互关注,记录这种关系是followers表(follower_id 发起关注的人 followed_id被关注的人) 现在多对多关系就不再是传统三张表关系了, 这种情况 多对多关系应该怎么声明呢...分析 laravel或者其他框架多对多关系 一般都是由Model1 Model2 Model1_Model2(声明两者关系表)来组成, 但是上面的场景 却是只有两张表,这时候就要研究下官方文档了...方法传递参数是可以定制 以达到个性化需求, 第一个参数是 第二个Model 第二个参数是 关系表名 第三个参数是 第一个Model在关系表中外键ID 第四个参数是 第二个Model在关系表中外键...关系表名是 ‘followers’ /** * 关注当前用户 * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany...} 以上这篇浅谈laravel5.5 belongsToMany自身正确用法就是小编分享给大家全部内容了,希望能给大家一个参考。

1.2K31

Laravel中使用路由控制权限(不限于Laravel,只是一种思想)

Start 权限设计是后台管理很重要一个功能,所以要好好设计。 PHP 已经有很多这方面的packages了,就不用我们重复造轮子了。...每一个页面认证当前需要权限一次 在统一地方(中间件)验证 先上一下简单表结构(只保留重要信息)数据库模型 ER 图 数据库模型图 (ps:这个设计中,用户不会直接拥有权限,只能通过角色继承权限...{ return $this->belongsToMany(User::class); } // 角色权限模型关联关系 public function permissions...php namespace App\Models; class Permission extends Model { // 角色权限模型关联关系 public function...,还是要在不同方法进行验证,而且可扩展性不高,这时候我们只需要在权限表加一个字段,就可以解决问题 1. permissions (加多一个 route 字段, 如果不在 laravel 中使用,可以加一个

15110
您找到你想要的搜索结果了吗?
是的
没有找到

PHP-web框架Laravel-Eloquent ORM(二)

三、模型关联Laravel框架中Eloquent ORM提供了方便模型关联功能,用于定义不同表之间关联关系。下面是几个常用模型关联类型。...User模型一个Phone模型,通过在User模型中定义phone方法和在Phone模型中定义user方法,实现了这两个模型之间一对一关联关系。...Post模型一个Comment模型,通过在Post模型中定义comments方法和在Comment模型中定义post方法,实现了这两个模型之间一对多关联关系。...其中,hasMany方法表示一个Post模型拥有多个Comment模型,belongsTo方法表示一个Comment模型属于一个Post模型。多对多关联多对多关联表示两个模型之间存在多对多关联关系。...(User::class); }}上述代码中,定义了一个User模型一个Role模型,通过在User模型中定义roles方法和在Role模型中定义users方法,实现了这两个模型之间多对多关联关系

60941

深入理解 Laravel Eloquent(三)——模型间关系(关联)

中文文档: http://laravel-china.org/docs/eloquent#relationships 下面我们开始一个一个地学习。...假如我们有两个模型:User Account,分别对应注册用户消费者,他们是一对一关系,那么如果我们要使用 Eloquent 提供一对一关系方法,表结构应该是这样: user: id ......pay: id ... ... user_id User Pay 具有一对多关系,换句话说就是一个 User 可以有多个 Pay,这样的话,只在 Pay 表中存在一个 `user_id` 字段即可。...多对多关系之前关系完全不一样,因为多对多关系可能出现很多冗余数据,用之前自带表存不下了。...我们可以使用一个重要特性,关系预载入:http://laravel-china.org/docs/eloquent#eager-loading 直接上代码: $users = User::with('

2.6K30

Laravel关系模型指定条件查询方法

对于关系模型来说,有时候我们需要甄别关联后结果,例如,班级学生是一对多关联,我现在查询班级,但是想只显示正常状态,即状态为1学生,因为有的学生从这个班级里面删除了,状态是4,那么我们在查询时候就可以使用如下语法...: 1、定义关联关系: Class模型: public function learners() { return $this- belongsToMany('App\Models\Customer'...learner_relation', 'class_id', 'learner_id'); } Customer模型: public function learnerclasses() { return $this- belongsToMany...learner_relation.status', 1) - orderBy('learner_relation.create_time', 'desc'); }, ]) - find($id); 然后得到结果就是我们想要正常学生...以上这篇Laravel关系模型指定条件查询方法就是小编分享给大家全部内容了,希望能给大家一个参考。

1.8K41

Laravel多对多关系详解【文章 - 标签】

这是我是文章表【articles】、标签表【tags】以及关系表【article_tag】 其中关系命名是[article_tag]而不是tag_article 因为laravel默认是以字母升序排列...可以在定义时候设置,但何必那么麻烦,按照默认规则来不是很好么? 另外就是,新建迁移文件顺序也有要求,关系表肯定是最后,然后文章表标签表好像随意,但我是先建文章表。...这里有两个外键,分别是文章表主键标签表主键。...我们使用 $this->belongsToMany() 来表明Eloquent关系,这里需要注意是如果你外键并不是 article_id tag_id ,你需要在第三个参数进行设置,写成类似下面这样...但还是会在tag表新建一个标签。

1.8K00

Laravel源码分析之模型关联

上篇文章我们主要讲了Eloquent Model关于基础CRUD方法实现,Eloquent Model中除了基础CRUD外还有一个很重要部分叫模型关联,它通过面向对象方式优雅地把数据表之间关联关系抽象到了...使用模型关联给应用开发带来收益我认为有以下几点 主体数据关联数据之间关系在代码表现上更明显易懂让人一眼就能明白数据间关系。...按照Laravel设定好模式来写关联模型每个人都能写出高效优雅代码 (这点我认为适用于所有的Laravel特性)。...定义一个多对多关联, 返回一个BelongsToMany关联关系实例 * * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany...模型关联常用一些功能底层实现到这里梳理完了,Laravel把我们平常用join, where in 子查询都隐藏在了底层实现中并且帮我们把相互关联数据做好了匹配。

9.5K10

Laravel Eloquent 模型关联关系详解(上)

Eloquent 模型支持关联关系包括以下七种: 一对一 一对多 多对多 远层一对多 多态关联(一对一) 多态关联(一对多) 多态关联(多对多) 下面我们将以设计一个简单博客系统数据库为例一一介绍上述关联关系...你可能注意到了我们在定义关联关系时,仅仅指定了模型类名,并没有指定通过哪些数据表字段建立关联,这并不是说 Laravel 神通广大,能知过去未来之事,而是因为 Eloquent 对此做了默认约定。...以博客系统为例,一个用户可以发布多篇文章,反过来,一篇只能归属于一个用户,那么用户和文章之间就是一对多关系,同样,用户可以发布多条评论,一条评论只能归属于一个用户,用户与评论之间也是一对多关系。...最后一个参数 $relation 表示关联关系名称,用于设置查询结果中关联属性,默认是关联方法名。...建立相对关联关系 与之前关联关系一样,多对多关联也支持建立相对关联关系,而且由于多对多双方是平等,不存在谁归属谁问题,所以建立相对关联方法都是一样,我们可以在 Tag 模型中通过 belongsToMany

9.8K40

orm 系列 之 Eloquent演化历程1

Eloquent Eloquent是laravelorm,采取是active record设计模式,里面的对象不仅包括领域逻辑,还包括了数据库操作,但是大家平时使用时候可能没有探究eloquent...note:以上分析代码是:git co f6e2170 讲到这,我们列举下对象之间关系 One-To-One User Phone1对1关系, class User extends Model...) Many To Many 以userrole为例,一个用户会有不同角色,一个角色也会有不同的人,这个时候就需要一张中间表role_user,代码声明上如下: class User extends...('App\User'); } } 这个关系我们稍微具体讲下,我们在使用上可能会是下面这样子 return $this->belongsToMany('App\Role', 'user_roles...role,join表user_role 在get时候,其逻辑HasOne等关系也所有不同,代码如下: // class belongsToMany public function get($columns

1K30

Laravel 多态关系表单验证

相信大家使用 Laravel 开发应用时候都会有评论模块吧,而且我们通常将该模块设计为多态关系(如果你对这个关系还不明白的话,请赶紧打开 Laravel 文档数据库关系章节复习一遍吧!)。...先看看我们数据库结构: id commentable_id commentable_type body 那么遇到一个问题,如果写入数据呢?...一般来讲有两种方式,而我们通常用一种是从父模型使用关系写入,比如我们有一个 App\Thread 类,它里面对评论关系是这样: class Thread {    public function...是不是简单很多,而且这样验证规则还能重用在其它同类多态关系地方哦。 这样就结束了么?没有! 我们上面的拓展验证规则写法没有感觉有些粗暴么?是时候规范一下了。...我们应该把所有的验证器都独立成一个类,放到 App\Validators 空间下,比如上面的关系验证我们可以叫做 App\Validators\PolyExistsValidator: <?

2.1K40

laravel ORM关联关系 withwhereHas用法

with 渴求式预加载 可以有效避免 N+1 问题,用法如下: $books = App\Book::with('author')- get(); 如果有多个关联关系可以用“,”隔开,还可以使用闭包来对关联关系进行限制...- where('title', 'like', '%first%'); }])- get(); 结果会查找所有的用户,返回每个用户信息中都会多一个posts数组,但是posts数组可能为空(不符合查询要求...,适合查找 存在不存在 感觉 with 更多用在查看详情时候,你想知道你查看对象具体信息,关联到内容是怎样, 而 whereHas 更多用在筛选,你要把符合条件关联关系对象给他找出来。...就像用户发文章, user 存在关联关系 post,如果是 user- with(‘post’),你会得到所有用户用户发布文章信息,没发文章用户就没有文章信息,如果是 user- whereHas...这就是我对 with whereHas 一些理解了 以上这篇laravel ORM关联关系 withwhereHas用法就是小编分享给大家全部内容了,希望能给大家一个参考。

3.8K31

Laravel学习记录--Model

Laravel 自带 软删除功能 就利用全局作用域从数据库中提取「未删除」模型。编写自定义全局作用域可以提供一个方便、简单方法来确保给定模型每个查询都受到一定约束。...使用渴求式加载,即根据预先需求查询出所有数据 为了验证[渴求式加载]好处,举下列例子 这里用到了Laravel Debugbar 调试 安装方法可参照我一个博客 - - - Laravel...true则查询关联对象本身 通过原生sql语句我们可以更好理解 当最后一个参数为false时 SQL: select `tags`.*, `media_tags`....`tagtable_type` = 'App\Article' 当最后一个参数为true时 select `tags`.*, `media_tags`....,使用updateExistingPivot方法 该方法接受中间记录另一个外键一个关联数组进行更新 public function show(){ $stu = Stu::find(

13.4K20

Laravel 模型关联基础教程详解

Laravel 中定义模型关联是每个 Laravel 开发者可能已经做过不止一次事情。但是在试图实现关联时可能会遇到各种问题。因为 Laravel 有各种各样关联,你应该选择哪一个?...举个例子,一个 User 模型一个 Passport 模型会成为一对一关联。一个用户只能拥有一张通行证,同样,一张通行证也只属于一个用户。 让我们看看如何在代码中定义这种关联。 <?...我们通过 hasOne 方法告诉 Laravel User 模型有一个 Passport 。 注意: 所有用于定义关联方法都有可选额外参数,你可以在这些参数中定义本地键外键。...这种类型关联意味着一个类型A模型可以链接到多个类型B模型。但是类型B模型只属于一个类型A模型。 例如,User 模型 Invoice 模型之间关联是一对多关联。...这种类型关联意味着类型A一个模型可以链接到类型B多个模型,反之亦然。 例如,Invoice 模型 Product 模型之间关联将是多对多关联。

5.5K31

谈谈我第一次如何为 Laravel 贡献源码

事件 Log 打印了一下返回变量,发现belongsToMany::sync方法返回 ID 并不正确。...belongsToMany 进一步查看,这个整数大小,很熟悉,觉得应该是整数类型大小溢出了。...溢出 然后我向框架提了一个issues Laravel 组织成员tillkruss 告诉我可以提交一个 PR 然后自己马上行动起来,说实话解决这个问题很简单,因为只要获取主键类型,然后进行强转即可...马上提交了代码,之后被驳回,原来是忘记了写测试代码 查看了一下其他数据库测试代码,找了一个比较符合我写了一个数据库测试。...尽情表达你想法,社区有很多人会帮助你 最后欢迎加入Laravel学习交流群,群号:584453488

9510

Laravel6.0.4中将添加计划任务事件方法步骤

此版本包括计划任务事件、新 JSON 断言方法所有最新更改。...让我们来看看这个版本中一些亮点新特性: 首先,在 TestResponse 类中添加了一个 assertJsonPath() 断言,对于在 JSON 响应中使用针对嵌套属性点符号断言值,这个断言非常方便...($name); $builder- getGlobalMacro($name); $builder- hasGlobalMacro($name); 向 BelongsToMany 关联添加另一个访问方法来获取中间表列...此版本中最后一个新更新是允许使用 inputargument inputoption 对象定义命令参数选项: // 当前样式,仍受支持 protected function getArguments...Laravel 5.8 完整发行说明可在 Github v6 changelog 中找到: Laravel v6.0.4 版本 新增 添加了 TestResponse::assertJsonPath(

1.7K21

PHP-web框架Laravel-Eloquent ORM(三)

四、查询构建器Laravel框架中Eloquent ORM提供了方便查询构建器,用于构建复杂查询语句。下面是一些常用查询构建器方法。...select方法select方法用于选择需要返回字段,例如:$users = User::select('name', 'email')->get();上述代码中,只返回用户姓名邮箱字段。...总结通过上述文档示例,我们可以看出Laravel框架中Eloquent ORM提供了便捷对象关系映射功能,可以大大简化开发者数据库操作。...它支持多种关联关系,包括一对一、一对多多对多等,并且提供了方便查询构建器,用于构建复杂查询语句。...关联关系定义需要在对应模型类中定义,例如一对一关联需要在hasOnebelongsTo方法中定义,一对多关联需要在hasManybelongsTo方法中定义,多对多关联需要在belongsToMany

1.5K41

Laravel5.1框架自带权限控制系统 ACL用法分析

分享给大家供大家参考,具体如下: Laravel在5.1.11版本中加入了Authorization,可以让用户自定义权限,今天分享一种定义权限系统方法。 1....delete-post,然后创建了 editor admin 两个角色,editor 角色拥有 edit-post 权限,而 admin 两个权限都有。...之后我们修改路由中用户ID为 2 ,然后再次刷新浏览器,可以看到,这次同时出现了 Edit Post Delete Post 两个链接,说明我们定义权限控制起作用了。 ?...更多关于Laravel相关内容感兴趣读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及...《php常见数据库操作技巧汇总》 希望本文所述对大家基于Laravel框架PHP程序设计有所帮助。

52061
领券