Jun
22
2019
laravel实现一对多关联模型数据查询
作者:
绝缘体.. 发布:
2019-06-22 15:45 分类:
未分类 阅读:
抢沙发
本文我们就是要通过laravel的一对多的关联模型来快速实现数据的调用。
假如我们现在有两张表:user 和 posts,每个 user 可以拥有多个 posts,而每一篇 posts 只能属于一个 user,两者的关系是明显的一对多关系。
user 表和 posts 表表结构如下:
CREATE TABLE `user` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `name` char(30) NOT NULL DEFAULT 'www.phpernote.com' COMMENT '名称', `ctime` timestamp NULL DEFAULT NULL COMMENT '创建时间', `utime` timestamp NULL DEFAULT NULL COMMENT '更新时间', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户表'; CREATE TABLE `posts` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `user_id` int(10) NOT NULL DEFAULT '1' COMMENT '用户表id', `title` char(30) NOT NULL DEFAULT '' COMMENT '标题', `content` text NOT NULL COMMENT '内容', `ctime` timestamp NULL DEFAULT NULL COMMENT '创建时间', `utime` timestamp NULL DEFAULT NULL COMMENT '更新时间', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='新闻表';
现在我们希望在获取某一篇 posts 的时候同时获取对应的 user 信息。
1、找到 users.php 模型文件,增加如下方法:
public function methodName() {
//hasMany($related, $foreignKey = null, $localKey = null)
//第一个参数为对应的model, 第二个参数默认为model对应的表的外键, 第三个参数默认为当前模型对应的表的主键
return $this->hasMany(Post::class, 'user_id', 'id');
}
2、找到 posts.php 模型文件,增加如下方法:
public function methodUser() {
//belongsTo($related, $foreignKey = null, $ownerKey = null, $relation = null)
//第一个参数为model, 先讲第四个参数,默认为调用belongsTo()的方法名字, 第二个参数默认为第四个参数加上 '_id', 第三个参数默认为model的对应表的主键
return $this->belongsTo(User::class, 'user_id', 'id');
}
3、找到 BlogController.php 增加查询数据方法:
public function index() {
//with:类似于 SQL 中的 left join
$posts = Post::with('methodUser')->get()->toArray();
echo '<pre>';print_r($posts);
}
结果打印数据类似为:
<pre>Array
(
[id] => 20
[user_id] => 11
[title] => "laravel实现一对多关联模型数据查询"
[content] => "本文我们就是要通过laravel的一对多的关联模型来快速实现......"
[ctime] => 1560422003
[utime] => 1560422003
[user] => Array
(
[id] => 11
[name] => phpernote_admin
[ctime] => 1560422003
[utime] => 1560422003
)
)
注意:
这实际上会执行下面两句 SQL 语句:
select * from `posts` select * from `user` where `user`.`id` in (<1>,<2>)
微信扫一扫,打赏作者吧~