黑马lavarel教程---10、lavarel模型关联
黑马lavarel教程---10、lavarel模型关联
一、总结
一句话总结:
1、模型关联比较方便,一次定义,后面都可以使用
2、关联关系 使用动态属性进行调用
1、一对多,多对多实例?
一对多:一篇文章有多个评论
多对多:一个文章可能有多个关键词,一个关键词可能被多个文章使用。
2、lavarel模型关联中关联代码是写在主模型中还是写在次模型中?
关联代码写在主模型中
谁是主模型谁是次模型根据实际需求进行分析,比如文章表和关键词表多对多关系,当要查所有文章对应的关键词的时候文章表就是主模型
3、lavarel关联关系的方法名称一般是什么?
被关联的模型名小写
public function 被关联的模型名小写(){
return $this -> hasOne(‘需要关联模型的命名空间’,’被关联模型的关系字段,’本模型中的关系字段’);
}
4、lavarel模型中如何设置一对多模型中的外键字段?
return $this->hasMany('App\Comment', 'foreign_key', 'local_key');
5、关联关系的使用方法?
使用动态属性进行调用:$roles = App\User::find(1)->roles()->orderBy('name')->get();
<?php namespace App;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
/**
* 用户的角色
*/
public function roles()
{
return $this->belongsToMany('App\Role');
}
}
一旦关联关系被定义后,你可以通过 roles 动态属性获取用户角色: $user = App\User::find(1); foreach ($user->roles as $role) {
//
}
当然,像其它所有关联模型一样,你可以使用 roles 方法,利用链式调用对查询语句添加约束条件: $roles = App\User::find(1)->roles()->orderBy('name')->get();
二、lavarel模型关联
关联模型就是绑定模型(表)的关系(关联表),后续需要使用联表的时候就可以直接使用关联模型。注意:关联模型必须要创建模型。
1、一对一关系
例如:一篇文章只有一个作者
①创建模型【前提】
#php artisan make:model Home/Article
#php artisan make:model Home/Author
②定义基本的结构代码
③关联模型的关联方法(重点)
注意:在写关联模型的时候要分析出是谁关联谁,谁做主动关联的模型?当前的案例是文章关联作者,需要关联代码写在主模型中。
语法:
public function 被关联的模型名小写(){
return $this -> hasOne(‘需要关联模型的命名空间’,’被关联模型的关系字段,’本模型中的关系字段’);
}
关联关系的使用方法:使用动态属性进行调用
案例:通过关联模型的一对一关系查询出每个文章对应的作者名称
①定义需要的路由
②创建需要的方法
使用一对一关联关系之后,其可以替代之前写join联表操作。
2、一对多关系
例如:一篇文章有多个评论
由于文章和评论的关系是一对多的关系,所以需要再去创建一个数据表(评论表):
字段id 主键
字段comment 评论内容
字段article_id 和文章的关系字段,文章id
①迁移文件的创建
#php artisan make:migration create_comment_table
②编写迁移文件代码
③执行迁移文件生成数据表
#php artisan migrate
④添加测试的评论内容
a. 创建填充器文件
#php artisan make:seeder CommentTableSeeder
b. 编写填充器文件的代码
c. 执行填充器文件
#php artisan db:seed --class=CommentTableSeeder
⑤评论模型创建起来
#php artisan make:model Home/Comment
定义其基本的属性:
案例:查询出每个文章(主)下所有的评论(从)。
关联关系的编写:
public function 被关联的模型名小写(){
return $this -> hasMany(‘需要关联模型的命名空间’,’被关联模型的关系字段,’本模型中的关系字段’);
}
与hasOne方法相比,其只是把方法名称做了变化,其他与之前一致。
编写test22方法实现上述案例的要求:
操作代码:
效果:
3、多对多关系
例如:一个文章可能有多个关键词,一个关键词可能被多个文章使用。
当点开关键词链接之后,会发现一个关键下能搜出很多文章。
因此,文章和关键词之间是多对多的关系。
对对多的关系经过拆分之后其实就是两个一对多的关系。由于是双向一对多的关系,因此光靠2张表是无法建立的关系的,需要依靠第三张表建立关系(xx与xx的关系表)。
当前已经存在文章表,因此还需要关键词表和关系表。
关键词表:
字段id 主键
字段keyword 关键词
文章与关键词的关系表:
字段id 主键
字段article_id 文章id
字段key_id 关键词id
简易模拟:
Id 关键词 id 文章id 关键词id
1 芳华 1 1 1
2 冯小刚 2 1 2
3 2 1
①创建需要迁移文件
#php artisan make:migration create_keyword_table
#php artisan make:migration create_relation_table
②编写迁移文件的代码
③执行迁移文件生成数据表
#php artisan migrate
④生成测试的数据
#php artisan make:seeder KeywordAndRelationTableSeeder
编写相关代码:
执行填充器文件:
#php artisan db:seed --class=KeywordAndRelationTableSeeder
⑤创建需要的模型
注意:根据手册中记录的语法要求,不需要给关系表单独的创建模型。
该处只需要单独给keyword创建模型即可
#php artisan make:model Home/Keyword
定义模型的基本内部结构
案例:查询出每个文章下全部的关键词
语法:return $this -> belongsToMany(被关联模型的元素空间路径,多对多模型的关系表名,当前模型中的关系键,被关联模型的关系键);
根据案例的要求,此处的关系映射依旧写在文章模型中
编写test23方法,实现刚才案例的需要:
显示效果:
黑马lavarel教程---10、lavarel模型关联的更多相关文章
- 黑马lavarel教程---5、模型操作(AR模式)
黑马lavarel教程---5.模型操作(AR模式) 一.总结 一句话总结: AR: ActiveRecord :Active Record(活动记录),是一种领域模型模式,特点是一个模型类对应关系型 ...
- 黑马lavarel教程---1、lavarel目录结构
黑马lavarel教程---1.lavarel目录结构 一.总结 一句话总结: 一套视频讲的东西太少,要看多套视频 1.安装lavarel需要额外开启的模块? extension=php_filein ...
- 黑马lavarel教程---13、分页
黑马lavarel教程---13.分页 一.总结 一句话总结: - lavarel里面的分页操作和tp里面的分页操作几乎是一模一样的 - 控制器:$data=Lesson::paginate(2); ...
- 黑马lavarel教程---7、文件上传
黑马lavarel教程---7.文件上传 一.总结 一句话总结: 在laravel里面实现文件的上传是很简单的,压根不用引入第三方的类库,作者把上传作为一个简单的http请求看待的. 1.在lavar ...
- 黑马lavarel教程---6、简单验证
黑马lavarel教程---6.简单验证 一.总结 一句话总结: 1.验证的最简单实例:$request的validate方法,验证通过可以继续进行,验证失败就重定向 2.中文提示可以用中文语言包 3 ...
- 黑马lavarel教程---9、缓存操作
黑马lavarel教程---9.缓存操作 一.总结 一句话总结: legend2项目中自己写的哪些文件操作都可以通过这里的缓存实现,简单方便 1.lavarel中如何使用后端主流的缓存如 Memcac ...
- 黑马lavarel教程---12、lavarel验证码
黑马lavarel教程---12.lavarel验证码 一.总结 一句话总结: 用插件的时候仔细看插件的版本要求 1.lavarel安装验证码插件的时候,如果(可选)需要定义自己的配置,则需要生成配置 ...
- 黑马lavarel教程---11、响应处理
黑马lavarel教程---11.响应处理 一.总结 一句话总结: 如果在昂扬状态,看学习视频和运动时间重合,会很舒服 1.jquery的$.post参数为什么不需要占位? 因为每个参数的类型不同,可 ...
- 黑马lavarel教程---8、session
黑马lavarel教程---8.session 一.总结 一句话总结: 1.session默认保存在文件中 2.使用的话通过Session门面或者辅助函数 1.lavarel中session的保存方式 ...
随机推荐
- JS的 delete操作符 删除对象属性
JS如何删除对象中的某一属性 var obj={ name: 'zhagnsan', age: 19 } delete obj.name //true typeof obj.name //undefi ...
- 初识 vue------简单介绍
/** vue 作者:尤雨溪 类型:MVVM 准确的来说是MV框架 为什么要学习vue 1.传统的项目是通过操作dom元素来修 ...
- 正着打星星(js)
//让用户输入行数,使用for循环嵌套打出正着的星星来,行数等于用户输入的数字 //例如:用户输入6 // * // *** // ***** // ******* // ********* // * ...
- 云端js动态效果
效果图: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ...
- Java实现文本中的关键字高亮,匹配所有长度
这个方法还不完整,后面想起来再看,直接放代码 public static String getHeightlightWord(String textWord, String key){ StringB ...
- Tomcat设置默认启动项目
Tomcat设置默认启动项目 Tomcat设置默认启动项目,顾名思义,就是让可以在浏览器的地址栏中输入ip:8080,就能访问到我们的项目.具体操作如下: 1.打开tomcat的安装根目录,找 ...
- 如何使windows7的默认共享可以被访问[转载]
因为UAC的存在, 如果使用windows 7 的默认共享,比如 \abcc$ ,会被提示 无权限错误. 为了方便在局域网共享文件,找到了这个方法. Open the registry edi ...
- 6、SSH远程管理服务实战
1.SSH基本概述 SSH是一个安全协议,在进行数据传输时,会对数据包进行加密处理,加密后在进行数据传输.确保了数据传输安全.那SSH服务主要功能有哪些呢? 1.提供远程连接服务器的服务. 2.对传输 ...
- 卸载CUDA和cuDNN
卸载CUDA和cuDNN 1.卸载CUDA 本教程只针对对于.run方式安装的,其他的没有进行测试 打开终端,输入sudo /usr/local/cuda-10.0/bin/uninstall_cud ...
- 编译TensorFlow-serving GPU版本
编译TensorFlow-serving GPU版本 TensorFlow Serving 介绍 编译GPU版本 下载源码 git clone https://github.com/tensorflo ...