首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在视图中使用变量的替代方法

在视图中使用变量的替代方法
EN

Stack Overflow用户
提问于 2020-11-14 02:58:56
回答 1查看 90关注 0票数 0

我需要一些帮助构建一条SQL语句,该语句将输出每个客户端的前5个退役资产,这些资产可以放入SQL视图中。

我已经构建了以下SQL语句,但它不能在视图中工作,需要一个替代语句。

代码语言:javascript
运行
复制
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视图中工作。

EN

回答 1

Stack Overflow用户

发布于 2020-11-14 03:52:29

在MySQL 8.0中,这应该是:

代码语言:javascript
运行
复制
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之前,您必须在使用它时写出完整的查询。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64826558

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档