Laravel关联查询时,如何让字段自带表前缀?

例子中的关联查询,别管用不用得到关联users表,我都得在所有字段面前加上orders.,请问有没有什么办法能省去orders.

$query = Order:query()

//根据支付状态查询
if ($request->is_pay) {
    $query->where('orders.is_pay', $request->is_pay);
}

//根据用户手机号查询
if ($request->user_mobile) {
    $query->leftJoin('users', 'users.id', '=', 'orders.user_id')
        ->where('users.mobile', $request->user_mobile);
}
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 21

必须要这么干的,不然sql语义不明确,表名太长的话,你可以起别名

1周前 评论
勇敢的心 (楼主) 1周前
忆往昔弹指间 (作者) 1周前
忆往昔弹指间 (作者) 1周前
勇敢的心 (楼主) 1周前

个人建议用模型关联,不用写那么多if。少用这些Join

1周前 评论
南街古巷 (作者) 1周前
勇敢的心 (楼主) 1周前
勇敢的心 (楼主) 1周前
南街古巷 (作者) 1周前
勇敢的心 (楼主) 1周前
wade 1周前
勇敢的心 (楼主) 1周前

用 ORM 好一些

1周前 评论

换成with咋样

1周前 评论
陈先生

冒昧问一下,这个问题解答了你还会删除问题么?

1周前 评论
勇敢的心 (楼主) 1周前
陈先生 (作者) 1周前
sanders

建议使用模型关系

// 定义模型关系
public function user ()
{
    return $this->hasOne(User::class);
}
$query = Order:query()

//根据支付状态查询
$query->when($request->is_pay, fn($q) => $q->where('is_pay', $request->is_pay));
//根据支付状态查询
$query->when($request->user_mobile, fn($q) => $q->whereHas('user', fn($r) => $r->where('mobile', $request->user_mobile)));
1周前 评论

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