Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/72.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
SQL中每个月的第一个值_Sql_Timestamp - Fatal编程技术网

SQL中每个月的第一个值

SQL中每个月的第一个值,sql,timestamp,Sql,Timestamp,我有一个包含时间戳数据值的数据库,每天有多个样本,即 05/01/11 01:00:00 - 1.23 05/01/11 01:12:34 - 0.99 .... 05/01/11 23:59:59 - 2.34 05/02/11 00:11:22 - 4.56 等 我想得到每个月第一批样品的清单。我已设法在每个月1日获得每个样本的列表: 选择 “RecordTime”、“FormattedValue” 从…起 历史的 哪里 “Id”=12345,提取日期(从“记录时间”算起)

我有一个包含时间戳数据值的数据库,每天有多个样本,即

05/01/11 01:00:00 - 1.23  
05/01/11 01:12:34 - 0.99  
....  
05/01/11 23:59:59 - 2.34  
05/02/11 00:11:22 - 4.56

我想得到每个月第一批样品的清单。我已设法在每个月1日获得每个样本的列表:

选择
“RecordTime”、“FormattedValue”
从…起
历史的
哪里
“Id”=12345,提取日期(从“记录时间”算起)=1
这提供了如下数据:

03/01/11 00:00:01 - 1.23  
03/01/11 00:12:34 - 0.99  
....  
04/01/11 00:00:34 - 2.34  
04/01/11 00:11:22 - 4.56

但是我无法获得每个组的第一个值。

这里有一个SQL Server的解决方案。其思想是使用相关子查询来识别 每年和每月的最小
记录时间。将这个想法转化为您喜欢的DBMS应该很容易

WITH Data AS (
    SELECT CONVERT(DATETIME, '1-May-2011 01:00:00') AS RecordTime, 1.23 AS FormattedValue
    UNION ALL SELECT CONVERT(DATETIME, '1-May-2011 01:12:34'), 0.99
    UNION ALL SELECT CONVERT(DATETIME, '1-May-2011 23:59:59'), 2.34
    UNION ALL SELECT CONVERT(DATETIME, '2-May-2011 00:11:22'), 4.56
)
SELECT D1.*
FROM Data D1
WHERE D1.RecordTime = (SELECT MIN(RecordTime)
                       FROM Data D2
                       WHERE YEAR(D2.RecordTime) = YEAR(D1.RecordTime)
                       AND MONTH(D2.RecordTime) = MONTH(D1.RecordTime))
编辑:如果您的数据集很大,那么加入子查询应该会更快,但可能更难转化为您喜欢的DBMS:

SELECT D1.*
FROM Data D1
INNER JOIN (
    SELECT MIN(D2.RecordTime) AS FirstMonthlyRecordTime
    FROM Data D2
    GROUP BY YEAR(D2.RecordTime), MONTH(D2.RecordTime)
) AS SubQuery
    ON D1.RecordTime = SubQuery.FirstMonthlyRecordTime
编辑2:以下代码是我上面第一个查询的标准SQL-92版本(在mySQL上测试):


你在使用Oracle吗?您只是想获取每天的第一条记录吗?什么DBMS?SQL Server中的答案将与Oracle中的答案大不相同,Oracle中的答案将与MySQL中的答案大不相同,等等
SQL
的信息不足以提供答案。@肯·怀特:代码是标准的SQL-92,所以我认为
SQL
标记就足够了(即,为什么不使用标准的SQL-92发布答案?)OP的代码是标准的SQL-92,SQL Server不支持,但支持AIK PostgreSQL,Oracle和mySQL都有。我添加了第一个查询的SQL-92版本。
SELECT T1.RecordTime, T1.FormattedValue
FROM CDBHistoric T1
WHERE T1.RecordTime = (SELECT MIN(T2.RecordTime)
                       FROM CDBHistoric T2
                       WHERE EXTRACT(YEAR FROM T1.RecordTime) = EXTRACT(YEAR FROM T2.RecordTime)
                       AND EXTRACT(MONTH FROM T1.RecordTime) = EXTRACT(MONTH FROM T2.RecordTime))