mysql中有三张表,a表,b表通过中间表c表相关联,b表某一字段为type,查询每个type中前10条数据
时间: 2023-04-04 15:02:56 浏览: 142
您好,根据您的描述,我可以回答您的问题。您可以使用以下 SQL 语句查询每个 type 中前 10 条数据:
SELECT * FROM (
SELECT a.*, b.type, ROW_NUMBER() OVER (PARTITION BY b.type ORDER BY a.id) AS rn
FROM a
JOIN c ON a.id = c.a_id
JOIN b ON b.id = c.b_id
) AS t
WHERE t.rn <= 10;
其中,a 表、b 表和 c 表分别为三张表,a 表和 b 表通过 c 表相关联,b 表中的 type 字段表示类型。这个 SQL 语句会查询每个 type 中前 10 条数据,并按照 id 排序。希望这个回答能够帮到您。
阅读全文