我需要一些帮助构建一条SQL语句,该语句将输出每个客户端的前5个退役资产,这些资产可以放入SQL视图中。
我已经构建了以下SQL语句,但它不能在视图中工作,需要一个替代语句。
SET @row_number := 0;
SELECT DISTINCT NAME, RetiredDate, COMMENT,
@row_number:=CASE WHEN @client_ID=clientID THEN @row_number+1 ELSE 1 END AS num,
@client_ID:=clientID ClientID
FROM `retiredassets`
WHERE `retiredassets`.`ClientID` IN(SELECT clientID FROM `clients`)
HAVING num <=5
有人对我有什么建议吗?上面的语句可以完美地工作,但不能在SQL视图中工作。
发布于 2020-11-14 03:52:29
在MySQL 8.0中,这应该是:
WITH cte AS (
SELECT r.NAME, r.RetiredDate, r.COMMENT,
ROW_NUMBER() OVER (PARTITION BY r.ClientID ORDER BY ...) AS num,
r.ClientID
FROM retiredassets
JOIN clients USING (ClientID)
)
SELECT * FROM cte WHERE num <= 5;
我离开了...
,因为我不知道你点的是什么。您的原始查询没有指定订单,因此您必须选择一个。
请回复您的评论。
如果不能升级到MySQL 8.0,并且不能在视图定义中使用变量,那么就不能使用视图。在升级到MySQL 8.0之前,您必须在使用它时写出完整的查询。
https://stackoverflow.com/questions/64826558
复制相似问题