【问题标题】:MySQL query variable not set on new sessionMySQL 查询变量未在新会话上设置
【发布时间】:2020-02-17 03:25:29
【问题描述】:

我通过 MySQLWorkbench 运行以下查询。该查询应返回 table1 中 col2 的当前行和上一行之间的差异。每次我启动一个新的数据库会话并运行查询时,diff 列都会显示 null,但是当我第二次运行它时,diff 值会正确显示。如何让它在第一次运行时正确运行?

 select col1, col2 - @prev as diff , @prev:= col2  
   from table1

【问题讨论】:

  • 使用会话变量时默认为空。

标签: mysql variables


【解决方案1】:

使用以下查询获取结果。

 select col1
      , coalesce(col2 - @prev, 0) as diff 
      , @prev as previous
      , @prev := col2 as temp_prev  
   from table1
   join (select @prev := null) t;

【讨论】:

  • 谢谢!那行得通。您能否在此查询中添加一些关于 @prev 发生了什么的解释。我想了解这个问题是如何解决的。
  • 通常任何value - NULL 始终是NULL,因此在第一次执行查询时,所有行都返回NULL。但在那之后,您的@prev 将具有col2 的最后一个值。因此,当您在不重新启动会话 col2 - last_col2 的情况下再次执行时,这将再次导致错误,除非您在该列中对值进行了排序。
  • 在我的查询中,我只是在继续之前set @prev = null,并且我添加了合并以避免 null 并将结果显示为 0。第 1 行中的 previous 将为我们在连接中初始化的 null .然后我们使用 set 将 @prev 中的第一行 col2 存储为 temp_prev。请注意,如果您将previous 放在temp_prev 旁边的最后一个位置,则该值将与temp_prev 相同,因为我们刚刚分配了@prev。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多