[英]How to use Multi table queries in Laravel without using Eloquent Relationships
我正在使用 Laravel 为我的应用程序创建 API,稍后它将与反应前端集成。 我有两张表,发布和评论。 帖子表包含有关帖子的信息,评论表包含有关每个帖子的评论数据。 下面是结构,
post_id(主键) post_title post_description
comment_id(主键) comment_text post_id(外键)
我需要从帖子表中获取 post_id、post_title 以及评论表中每个帖子的总评论数,并希望 json 数据像这样显示
{
"post_id": 1,
"post_title": "some title",
"total comments": "4"
},
我知道如何为这些编写 sql 查询,但只是在显示上述数据时遇到问题。 下面是我正在使用的代码。
$allPostQuery= DB::select('select * from post');
foreach($allPostQuery as $allPostQuery)
{
$postId= $allPostQuery->post_id;
$totalCommentsQuery= DB::select('select count(comment_id) as totalComments from comment where post_id=:postId',["postId" => $postId ]);
}
return \Response::json([$allPostQuery,$totalCommentsQuery]);
但这不起作用。 我对循环发布帖子 ID 以获得每个帖子的总评论感到困惑。 我是否必须在前端使用 react foreach 循环来执行此操作? 任何人都可以提出任何帮助。 谢谢
根据您的问题,您只需要每个帖子的帖子 ID、标题和评论数:
$query = DB::select('
SELECT
p.post_id,
p.title,
c.total AS totla_comments
FROM posts p
INNER JOIN
(
SELECT post_id, COUNT(post_id) AS total FROM comments WHERE comments.post_id = post_id
GROUP BY post_id
) c
ON p.post_id = c.post_id
');
echo json_encode($query);
如果您希望数据返回应为 JSON 格式,请使用json_encode
(Laravel 有->json()
函数)。
看看你的方法:
这将影响您的性能速度,应该避免。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.