azure-stream-analytics - 当列存在时,流分析中的列名无效
问题描述
给定这个数据集:
[
{
"dataChannelId": 8516,
"measures": [
{
"dateTime": "2019-01-01T12:00:00",
},
{
"dateTime": "2019-01-02T12:00:00",
}
}]
这个查询:
WITH
temp AS
(
SELECT
dataChannelId,
arrayElement.ArrayValue as element
FROM GriegInputStream
CROSS APPLY GetArrayElements([mesurasdfes]) AS arrayElement
)
SELECT
temp.dataChannelId as sensorId, temp.element.dateTime, temp.element.value,temp.element.unit,temp.element.maxValue, temp.element.minValue
INTO
Sensoroutput
FROM
temp
我得到无效的列名,dataChannelId 上不存在,但措施似乎工作正常。如何在没有流分析抱怨的情况下访问此值?
解决方案
您的示例 json 数据缺少方括号]
。
样本数据:
[
{
"dataChannelId": 8516,
"measures": [
{
"dateTime": "2019-01-01T12:00:00",
},
{
"dateTime": "2019-01-02T12:00:00",
}
]
}
]
查询sql:
WITH
temp AS
(
SELECT
jsoninput.dataChannelId,
arrayElement.ArrayValue as element
FROM jsoninput
CROSS APPLY GetArrayElements(jsoninput.measures) AS arrayElement
)
SELECT
temp.dataChannelId as sensorId, temp.element.dateTime
INTO
Sensoroutput
FROM
temp
输出:
推荐阅读
- c++ - 下面的 boost 代码有什么作用?
- python - 多个索引一个类?
- php - 我想从 DB::Select get() 中获取“INT”值
- postgresql - 有人可以帮我将此 sqlite 查询转换为 postgres 查询吗?
- c# - 如何在 Android Studio 上调用 ASP.Net C# WCFService?
- r - 为满足条件 R 的每一行创建一个新列
- javascript - 为什么我不能选择文本(jqgrid输入)
- eloquent - 如何使用 Eloquent 更改 SoftDelete 数据格式?
- postgresql - 获取记录直到总和等于某个否
- javascript - “while 循环”返回意外的“未定义”