- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下查询,其中包含特定区域每分钟的温度和相对湿度信息:
SELECT plands.land AS Land,
ROUND(AVG(meteorology.temperature),2) AS Temperatureday,
ROUND(AVG(meteorology.humidity),2) AS Humidityday,
WEEKOFYEAR(meteorology.date) AS Week
FROM meteorology
INNER JOIN plands ON plands.id = meteorology.id_land
WHERE DATE(meteorology.date) BETWEEN '2016-09-12' AND '2016-09-23'
AND TIME(meteorology.date) >= '06:00:00'
AND TIME(meteorology.date) <= '18:00:00'
GROUP BY meteorology.id_land,
WEEKOFYEAR(meteorology.date),
YEAR(meteorology.date)
UNION ALL
SELECT plands.land AS Land,
ROUND(AVG(meteorology.temperature),2) AS TemperatureNight,
ROUND(AVG(meteorology.humidity),2) AS HumidityNight,
WEEKOFYEAR(meteorology.date) AS Week
FROM meteorology
INNER JOIN plands ON plands.id = meteorology.id_land
WHERE DATE(meteorology.date) BETWEEN '2016-09-12' AND '2016-09-23'
AND (TIME(meteorology.date) < '06:00:00'
OR TIME(meteorology.date) > '18:00:00')
GROUP BY meteorology.id_land,
WEEKOFYEAR(meteorology.date),
YEAR(meteorology.date)
显示如下:
----------------------------------------------------------
Land | Temperatureday | Humidityday | Week |
----------------------------------------------------------
LAND1 | 16.13 | 92.03 | 37 |
----------------------------------------------------------
LAND1 | 16.46 | 84.35 | 38 |
----------------------------------------------------------
LAND1 | 9.37 | 99.0 | 37 |
----------------------------------------------------------
LAND1 | 9.95 | 99.0 | 38 |
----------------------------------------------------------
但我要显示的数据如下:
------------------------------------------------------------------------------
Land | Temperatureday | Humidityday |TemperatureNight | HumidityNigh |Week|
------------------------------------------------------------------------------
LAND1 | 16.13 | 92.03 | 9.37 | 99.0 | 37 |
------------------------------------------------------------------------------
LAND1 | 16.46 | 84.35 | 9.95 | 99.0 | 38 |
------------------------------------------------------------------------------
我知道我的查询是错误的,但我不知道我在做什么。
谢谢!
最佳答案
连接数据的另一种方法涉及白天数据的子查询,您可以通过第二个外部查询JOIN
夜间数据作为附加详细信息。这适用于将子查询具体化为临时表的查询引擎,例如 MySQL。
SELECT wxday.Land, Temperatureday, Humidityday,
ROUND(AVG(meteorology.temperature),2) AS TemperatureNight,
ROUND(AVG(meteorology.humidity),2) AS HumidityNight,
wxday.Week
FROM (
SELECT plands.land AS Land,
ROUND(AVG(meteorology.temperature),2) AS Temperatureday,
ROUND(AVG(meteorology.humidity),2) AS Humidityday,
WEEKOFYEAR(meteorology.date) AS Week,
YEAR(meteorology.date) AS Year
FROM meteorology
INNER JOIN plands ON plands.id = meteorology.id_land
WHERE DATE(meteorology.date) BETWEEN '2016-09-12' AND '2016-09-23'
AND TIME(meteorology.date) >= '06:00:00'
AND TIME(meteorology.date) <= '18:00:00'
GROUP BY meteorology.id_land,
WEEKOFYEAR(meteorology.date),
YEAR(meteorology.date)
) AS wxday
INNER JOIN meteorology
ON (wxday.Land = meteorology.id_land
AND WEEKOFYEAR(meteorology.date) = wxday.Week
AND YEAR(meteorology.date) = wxday.Year)
WHERE DATE(meteorology.date) BETWEEN '2016-09-12' AND '2016-09-23'
AND (TIME(meteorology.date) < '06:00:00'
OR TIME(meteorology.date) > '18:00:00')
GROUP BY wxday.Land, wxday.Week, wxday.Year
第二种方法保留 UNION
,将日夜数据放在单独的输出列中,然后使用 MIN
将它们合并。这是有效的,因为具有一个非空值和一个 NULL
的组的 MIN
是一个非空值。在某些星期有夜间数据但没有白天数据或反之亦然的情况下,它可能会更好地工作:
SELECT Land,
MIN(Temperatureday) AS Temperatureday,
MIN(Humidityday) AS Humidityday,
MIN(TemperatureNight) AS TemperatureNight,
MIN(HumidityNight) AS HumidityNight,
Week
FROM (
SELECT plands.land AS Land,
ROUND(AVG(meteorology.temperature),2) AS Temperatureday,
ROUND(AVG(meteorology.humidity),2) AS Humidityday,
NULL AS TemperatureNight,
NULL AS HumidityNight,
WEEKOFYEAR(meteorology.date) AS Week,
YEAR(meteorology.date) AS Year
FROM meteorology
INNER JOIN plands ON plands.id = meteorology.id_land
WHERE DATE(meteorology.date) BETWEEN '2016-09-12' AND '2016-09-23'
AND TIME(meteorology.date) >= '06:00:00'
AND TIME(meteorology.date) <= '18:00:00'
GROUP BY meteorology.id_land,
WEEKOFYEAR(meteorology.date),
YEAR(meteorology.date)
UNION ALL
SELECT plands.land AS Land,
NULL AS TemperatureNight,
NULL AS HumidityNight,
ROUND(AVG(meteorology.temperature),2) AS TemperatureNight,
ROUND(AVG(meteorology.humidity),2) AS HumidityNight,
WEEKOFYEAR(meteorology.date) AS Week,
YEAR(meteorology.date) AS Year
FROM meteorology
INNER JOIN plands ON plands.id = meteorology.id_land
WHERE DATE(meteorology.date) BETWEEN '2016-09-12' AND '2016-09-23'
AND (TIME(meteorology.date) < '06:00:00'
OR TIME(meteorology.date) > '18:00:00')
GROUP BY meteorology.id_land,
WEEKOFYEAR(meteorology.date),
YEAR(meteorology.date)
) AS itsownalias
GROUP BY Land, Week, Year
第三种方法通过数据传递并使用 AVG
,依赖于其相同的 NULL
跳过行为。这也可以在没有子查询的情况下表达,但是 IsDay
使其更具可读性并且更符合 "Don't repeat yourself" principle .
SELECT Land,
ROUND(AVG(CASE IsDay WHEN 0 THEN NULL ELSE temperature END),2) AS Temperatureday,
ROUND(AVG(CASE IsDay WHEN 0 THEN NULL ELSE humidity END),2) AS Humidityday,
ROUND(AVG(CASE IsDay WHEN 0 THEN temperature ELSE NULL END),2) AS TemperatureNight,
ROUND(AVG(CASE IsDay WHEN 0 THEN humidity ELSE NULL END),2) AS HumidityNight,
WEEKOFYEAR(meteorology.date) AS Week
FROM (
SELECT plands.land AS Land,
meteorology.temperature,
meteorology.humidity,
WEEKOFYEAR(meteorology.date) AS Week,
YEAR(meteorology.date) AS Year,
CASE WHEN TIME(meteorology.date) >= '06:00:00'
AND TIME(meteorology.date) <= '18:00:00'
THEN 1 ELSE 0 END AS IsDay
FROM meteorology
INNER JOIN plands ON plands.id = meteorology.id_land
WHERE DATE(meteorology.date) BETWEEN '2016-09-12' AND '2016-09-23'
) AS itsownalias
GROUP BY Land,
WEEKOFYEAR(meteorology.date),
YEAR(meteorology.date)
关于php - 查询带数据昼夜sql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39664829/
运行 PostgreSQL(7.4 和 8.x),我认为这是可行的,但现在我遇到了错误。 我可以单独运行查询,它工作得很好,但如果我使用 UNION 或 UNION ALL,它会抛出错误。 这个错误:
我试图为我的应用程序创建一个导航,使用抽屉导航我的 fragment 之一(HomeFragment)有一个 ViewPager,可容纳 3 个 fragment (Bundy Clock、Annou
以我目前正在开发的应用为例: - 它有一个包含多个项目的抽屉导航;现在有两个项目让我感兴趣,我将它们称为 X 和 Y。 X 和 Y 都在单击时显示包含 x 元素或 y 元素列表的 fragment 选
我有一个形状为 (370,275,210) 的 NumPy 数组,我想将其重新整形为 (275,210,370)。我将如何在 Python 中实现这一点? 370是波段数,275是行数,210是图像包
我们如何与被子 UIViewController 阻止的父 UIViewController(具有按钮)交互。显然,触摸事件不会通过子 Nib 。 (启用用户交互) 注意:我正在加载默认和自定义 NI
我是 Jpa 新手,我想执行过程 我的代码如下 private static final String PERSISTENCE_UNIT_NAME = "todos"; private static
与安装了 LAMP 的 GCE 相比,选择与 Google Cloud SQL 链接的 GCE 实例有哪些优势? 我确定 GCE 是可扩展的,但是安装在其上的 mysql 数据库的可扩展性如何? 使用
这个问题在这里已经有了答案: Value receiver vs. pointer receiver (3 个答案) 关闭 3 年前。 我刚接触 golang。只是想了解为 Calc 类型声明的两种
我不小心按了一个快捷键,一个非常漂亮的断线出现在日期上。 有点像 # 23 Jun 2010 -------------------- 有人知道有问题的快捷方式吗?? (我在 mac 上工作!) 在
我正在Scala中编写正则表达式 val regex = "^foo.*$".r 这很好,但是如果我想做 var x = "foo" val regex = s"""^$x.*$""".r 现在我们有
以下 XML 文档在技术上是否相同? James Dean 19 和: James Dean 19 最佳答案 这两个文档在语义上是相同的。在 X
我在对数据帧列表运行稳健的线性回归模型(使用 MASS 库中的 rlm)时遇到问题。 可重现的示例: var1 <- c(1:100) var2 <- var1*var1 df1 <- data.f
好的,我有一个自定义数字键盘,可以在标签(numberField)中将数字显示为 0.00,现在我需要它显示 $0.00。 NSString *digit = sender.currentTitle;
在基于文档的应用程序中,使用 XIB 文件,创建新窗口时其行为是: 根据最后一个事件的位置进行定位和调整大小 window 。 如果最后一个事件窗口仍然可见,则新窗口 窗口应该是级联的,这样它就不会直
我想使用参数进行查询,如下所示: SELECT * FROM MATABLE WHERE MT_ID IN (368134, 181956) 所以我考虑一下 SELECT * FROM MATABLE
我遇到一些性能问题。 我有一个大约有 200 万行的表。 CREATE TABLE [dbo].[M8]( [M8_ID] [int] IDENTITY(1,1) NOT NULL,
我在 jquery 中的按键功能遇到问题。我不知道为什么按键功能不起作用。我已经使用了正确的 key 代码。在我的函数中有 2 个代码,其中包含 2 个事件键,按一个键表示 (+) 代码 107 和(
我想显示音频波形,我得到了此代码,它需要.raw音频输入并显示音频波形,但是当我放入.3gp,.mp3音频时,我得到白噪声,有人可以帮助我如何使其按需与.3gp一起使用使用.3gp音频运行它。 Inp
我无法让 stristr 函数返回真值,我相信这是因为我的搜索中有一个 $ 字符。 当我这样做时: var_dump($nopricecart); 完整的 $nopricecart 值是 $0 ,我得
如果我有这样的循环: for(int i=0;i O(n) 次。所以do some执行了O(n)次。如果做某事是线性时间,那么代码片段的复杂度是O(n^2)。 关于algorithm - 带 If 语
我是一名优秀的程序员,十分优秀!