Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >SQL为一个日期选择多个最大值

SQL为一个日期选择多个最大值
EN

Stack Overflow用户
提问于 2019-07-01 20:37:38
回答 4查看 83关注 0票数 0

我试图通过使用max筛选列来从表中获取最新的记录,但是看起来我有多条记录对应于相同的最大日期。我在查询的末尾添加了order BY,看起来我实际上可以检索最新的值,因为它具有正确的顺序,但我不知道如何检索。

下面是一张描述性图片:

另外,请在下面找到我使用的查询:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT *
  FROM item_forecast_detail 
  WHERE item_id = 177010 AND
        forecast_dt = (SELECT MAX(forecast_dt)
                         FROM item_forecast_detail
                         WHERE item_id = 177010) 
  ORDER BY forecast_dt DESC
EN

回答 4

Stack Overflow用户

发布于 2019-07-01 20:45:25

使用row_number()窗口分析函数按需排序,使用max(forecast_dt) over (order by forecast_dt desc)检测最新日期

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT *
  FROM
  (
   SELECT d.*, 
          row_number() over (order by ending_hour desc) as rn,
          max(forecast_dt) over (order by forecast_dt desc) as mx
     FROM item_forecast_detail d
    WHERE item_id=177010 
   )
  WHERE mx = forecast_dt
  ORDER BY rn
票数 0
EN

Stack Overflow用户

发布于 2019-07-01 20:52:56

一种选择是应用另一个条件,例如获取最新的starting_hour

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SQL> with item_forecast_Detail (item_id, forecast_dt, starting_hour) as
  2    (select 177010, date '2019-07-07', 21 from dual union all
  3     select 177010, date '2019-07-07', 18 from dual union all
  4     select 177010, date '2019-07-07', 15 from dual union all
  5     select 177010, date '2019-07-07', 12 from dual union all
  6     --
  7     select 123456, date '2019-02-17', 09 from dual
  8    )
  9  select *
 10  from item_forecast_Detail i
 11  where i.item_id = 177010
 12    and i.forecast_dt = (select max(i1.forecast_dt)
 13                         from item_forecast_detail i1
 14                         where i1.item_id = i.item_id
 15                        )
 16    and i.starting_hour = (select max(i2.starting_hour)
 17                           from item_forecast_detail i2
 18                           where i2.item_id = i.item_id
 19                          );

   ITEM_ID FORECAST_D STARTING_HOUR
---------- ---------- -------------
    177010 07.07.2019            21

SQL>

另一种方法是使用分析函数对它们进行排序,并将其应用于最终查询:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SQL> with item_forecast_Detail (item_id, forecast_dt, starting_hour) as
  2    (select 177010, date '2019-07-07', 21 from dual union all
  3     select 177010, date '2019-07-07', 18 from dual union all
  4     select 177010, date '2019-07-07', 15 from dual union all
  5     select 177010, date '2019-07-07', 12 from dual union all
  6     --
  7     select 123456, date '2019-02-17', 09 from dual
  8    ),
  9  sort as
 10    (select i.*,
 11            row_number() over (partition by item_id order by forecast_dt, starting_hour desc) rn
 12     from item_forecast_Detail i
 13    )
 14  select *
 15  from sort s
 16  where s.item_id = 177010
 17    and s.rn = 1;

   ITEM_ID FORECAST_D STARTING_HOUR         RN
---------- ---------- ------------- ----------
    177010 07.07.2019            21          1

SQL>
票数 0
EN

Stack Overflow用户

发布于 2019-07-01 21:29:38

您可以尝试使用MySQL、SQLServer:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT * FROM TABLE ORDER BY FORECAST_DT DESC LIMIT 1

SELECT TOP 1 * FROM Table ORDER BY FORECAST_DT DESC
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56842155

复制
相关文章
如何在Java中处理JSON
New 一个 ObjectMapper对象,后续将利用这个ObjectMapper对象来进行一系列的操作。
泰坦HW
2020/07/22
1.5K0
MySQL 8.0 新特性:多值索引 --如何给JSON数组添加索引(三)
上一篇文章《MySQL如何给JSON列添加索引(二)》中,我们介绍了如何给JSON列添加索引,那么接下来,我们看下如何给JSON数组添加索引?
SEian.G
2021/07/07
14.7K1
java json数组转json对象_json对象数组
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/09/30
10K0
java json数组转json对象_json对象数组
vue遍历数组中的数组_vue数组转json
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/11/03
3.8K0
js 数组转json,json转数组[js 数组与json 互相转换]
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/151825.html原文链接:https://javaforall.cn
全栈程序员站长
2022/06/24
12K0
如何在MySQL中搜索JSON数据
从MySQL 5.7.8开始,MySQL支持本机JSON数据类型。在本教程中,我们将学习如何在MySQL中搜索JSON数据。
Lemon黄
2020/04/14
5.4K0
如何在CDH中使用Solr对HDFS中的JSON数据建立全文索引
温馨提示:要看高清无码套图,请使用手机打开并单击图片放大查看。 Fayson的github:https://github.com/fayson/cdhproject 提示:代码块部分可以左右滑动查看噢 1.文档编写目的 ---- Solr是一个高性能,采用Java开发,基于Lucene的全文搜索服务器。同时对其进行了扩展,提供了比Lucene更为丰富的查询语言,同时实现了可配置、可扩展并对查询性能进行了优化,并且提供了一个完善的功能管理界面,是一款非常优秀的全文搜索引擎。SolrCloud是Sol
Fayson
2018/07/12
6K0
[PHP] php中的索引数组和数组顺序问题
先上结论 , php的索引数组不是传统的从0开始的整数索引数组 , 而是一个关联数组 , 是一个有序的键值对 ,这个序就是定义时候的顺序
唯一Chat
2021/04/25
9.3K0
XML转成Json,数组转成Json,Json转成数组
1、数据交互经常用到XML或者Json,其中Json数据居多(优点不多说) 2、ZendFrameWork中如何将XML转换成Json以及数组和Json转换 直接上例子: $arr = array(‘status’ => 1, ‘info’ => ‘json测试’, ‘data’ => array(‘name’ => ‘用户名’, ‘password’ => ‘blog.phpfs.com’)); //数组转Json $json = Zend_Json::encode($arr);//$json =
苦咖啡
2018/05/08
5.2K0
JSON 数组
JSON 中数组值必须是合法的 JSON 数据类型(字符串, 数字, 对象, 数组, 布尔值或 null)。
陈不成i
2021/07/14
1.7K0
数组->Json
if(!$this->validate()) return false; $price_detail_1 = []; $price_detail = []; $price_detail_1[]['detail_name'] = $this->attributes['detail_name']; $price_detail_1[]['detail_price'] = $this->attributes['detail_price']; $price_detail_1[]['detail_unit'] = $t
botkenni
2022/01/10
1.1K0
取Json中的数组进行遍历
废话不多说,直接上代码  测试: String test = "{"list":[{"id":1,"qty":20,"type":"测试","time":"2022-08-02"},{"id":2,"qty":10,"type":"测试","time":"2022-08-02"},{"id":3,"qty":17,"type":"测试","time":"2022-08-02"}]}" JSONObject obj = JSONObject.fromObject(test); Object object
用户10175992
2022/11/15
4.3K0
java中数组转成list_java数组转json
1. 使用Arrays.asList生成的list是定长的,无法增加或删除元素,调用add或remove方法会抛出UnsupportedOperationException异常
全栈程序员站长
2022/09/25
1.3K0
javascript中json对象json数组json字符串互转及取值
今天用到了json数组和json对象和json类型字符串之间互转及取值,记录一下:
kirin
2020/10/30
4.8K0
php 数组转json对象 和json 数组
php中数组转json的规则是:当没有指定索引(0~n)时会转换为json数组,而指定了索引会转换为json对象。
全栈程序员站长
2022/06/24
6.4K0
js 数组转json和json转数组
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/151869.html原文链接:https://javaforall.cn
全栈程序员站长
2022/06/24
8K0
json字符串数组转json数组
当需要把一串字符串转成一个json 数组 ,并遍历其中的内容时。 首先要导入 net.sf.json.JSONArray和net.sf.json.JSONObject 两个jar 包
全栈程序员站长
2022/06/24
5.5K0
比 Elasticsearch 更快!RediSearch + RedisJSON = 王炸!
首先介绍下RedisMod这个东西,它是一系列Redis的增强模块。有了RedisMod的支持,Redis的功能将变得非常强大。目前RedisMod中包含了如下增强模块:
macrozheng
2022/04/12
1.5K0
比 Elasticsearch 更快!RediSearch + RedisJSON = 王炸!
点击加载更多

相似问题

在RediSearch中搜索多个索引

12

如何在Redisearch中删除索引中的所有文档?

131

rediSearch不能在db != 0上创建索引?

114

如何在RediSearch中使用@符号?

232

如何在RediSearch中存储日期/时间

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文