Laravel ORM 如何实现两表 IN 型查询 select * from a where pid in (select id from b) 效果?

问题:两张表laravel如何实现如下 SQL 语句 ?

SELECT * FROM `a` WHERE `pid` IN (SELECT `id` FROM b WHERE 1);

说明

1.使用 关联模型一直报错,不知道是不是应该用 关联一对一模型 呢?
2.或者使用原生 SQL 语句查询,这个查询如何 ->paginate(5); 分页查询呢?需要自己写个分页类来实现吗?

DB::select(‘SELECT * FROM `a` WHERE `pid` IN (SELECT `id` FROM b WHERE `cid` = ?)’, [$id]);
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 4

需要先给 A 添加 B 的映射

public function B()
{
    return $this->belongsTo(B::class, 'pid');
}

然后调用

A::whereHas('B', function ($_) {
    $_->where('id', 1);
})->get();

就可以了

分页的话

A::whereHas('B', function ($_) {
    $_->where('id', 1);
})->paginate(5);
7年前 评论

@柚子男

...
$id = 1;
A::whereHas('B', function ($_) {
    $_->where('id', 1);
})->get();

使用了你的方法,结果是出来了,但遇到个问题:变量不知如何传递。global 变量也不行,那么闭合函数如何传递参数呢?

  1. 代码中的 数字 1 是变量的话如何传递过去呢? 如上面的 $id = 1 ;
7年前 评论

@yaobaliu
闭包传参是 php 基础语法

$id = 1;
A::whereHas('B', function ($_) use($id) {
    $_->where('id', $id);
})->get();
7年前 评论

@柚子男
不好意思,第一次接触PHP闭包,昨天想成Jquery回调函数了。始终语法错误,这也算学习了,谢谢你!

7年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!