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]);
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
讨论数量: 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);
8年前 评论

@柚子男

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

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

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

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

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

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

8年前 评论

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