Laravel5.1 框架模型多态关联用法实例分析
时间:2022-07-27
本文章向大家介绍Laravel5.1 框架模型多态关联用法实例分析,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本文实例讲述了Laravel5.1 框架模型多态关联用法。分享给大家供大家参考,具体如下:
什么是多态关联? 一个例子你就明白了:好比如说评论 它可以属于视频类 也可以属于文章类,当有个需求是 从评论表中取到视频类的数据,这就需要用到多态关联了。
简单的一句话总结:一张表对应两张表。
1 实现多态关联
1.1 文章表的结构
public function up()
{
Schema::create('articles', function (Blueprint $table) {
$table- increments('id');
$table- string('title');
$table- text('body');$table- timestamps();
});
}
1.2 视频表结构
public function up()
{
Schema::create('videos', function (Blueprint $table) {
$table- increments('id');
$table- string('title');
$table- text('description');
$table- timestamps();
});
}
1.3 评论表结构
public function up()
{
Schema::create('comments', function (Blueprint $table) {
$table- increments('id');
$table- text('content');
$table- integer('item_id');
$table- string('item_type');
$table- timestamps();
});
}
↑ 这里需要指定 item_id 和 item_type 单一介绍一下 item_type 它主要是区别关联于那张表的 我们这里它只有两个值:AppArticle 或 AppVideo。
1.4 编写多态关联
Article 和 Video:
public function comments()
{
/**
* 第二个参数:如果你的前缀是item_ 那么就写item 如果是别的就写别的。
* 第三个参数:item_type
* 第四个参数:item_id
* 第五个参数:关联到那个表的键
* (以上除了第二个参数都可以省略)
*/
return $this- morphMany(Comment::class, 'item', 'item_type', 'item_id', 'id');
}
Comment:
public function video()
{
/**
* 三个参数都可以省略 不过K建议你还是写全
*/
return $this- morphTo('item', 'item_type', 'item_id');
}
使用:
Route::get('/', function () {
$video = AppVideo::find(8);
foreach ($video- comments as $comment) {
echo $comment- id . ": " . $comment- item_type;
}
});
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
- 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