【Azure Stream Analytic】用 JavaScript UDF 解决 JSON 字段被转成 Record 的关键点

问题描述

Azure Stream Analytics(ASA)将数据输出到下游并转换为CSV时,某些 JSON 字段(如 message)被自动转换成 Record 类型,导致原本期望的 JSON 字符串无法正常展示或被下游系统解析。

问题解答

出现该问题的主要原因是:ASA 在处理 JSON 对象时,如果输入字段是 JSON 对象(object 类型)而非 JSON 字符串,会在输出为 CSV 时默认序列化成 Record。

解答疑惑:为什么 JSON 字段会变成 Record

  • ASA 对输入字段进行类型推断:
    • 字符串 → 正常写入 CSV
    • 对象(Object) → 默认序列化为 Record
  • 当上游消息从"JSON 字符串"变成"JSON 对象"时,ASA 识别到的是结构化对象,因此在输出到 CSV 时自动以 Record 的方式呈现。
  • 因此需主动将 JSON 对象转换为字符串,最简方式是使用 JavaScript UDF。

解决步骤

第一步:创建 JavaScript UDF

  • 打开 ASA Job → 点击 Functions(函数)
  • 选择 Add FunctionJavaScript UDF
  • 填写函数名称(如 jsonstringify
  • 在编辑器中填写 JavaScript 代码
复制代码
function main(x) {
    return JSON.stringify(x);
}
  • 保存函数

第二步:在 ASA 查询中调用 UDF

在 ASA 查询内,对目标字段使用 UDF,例如:

复制代码
SELECT
UDF.jsonstringify(input.message) AS message,
*
INTO output

保存查询并启动作业后,JSON 对象将被转换成字符串并成功写入 CSV。

参考资料

JavaScript user-defined functions in Azure Stream Analytics : https://learn.microsoft.com/en-us/azure/stream-analytics/stream-analytics-javascript-user-defined-functions#other-javascript-user-defined-function-patterns


当在复杂的环境中面临问题,格物之道需:浊而静之徐清,安以动之徐生。 云中,恰是如此!

相关推荐
Heo1 小时前
深入React19任务调度器Scheduler
前端·javascript·面试
boooooooom1 小时前
Vue3 nextTick 实现大变化:微任务优先,彻底搞懂渲染时机!
javascript·vue.js·面试
用户14436183400971 小时前
你不知道的JS上-(九)
前端·javascript
冴羽2 小时前
2026 年 JavaScript 框架 3 大趋势
前端·javascript·react.js
思茂信息2 小时前
基于CST 3D Combined功能的以太网口RE仿真
开发语言·javascript·单片机·嵌入式硬件·matlab·3d
一拳不是超人3 小时前
从“必选项”到“性能包袱”:为什么现代框架开始“抛弃”虚拟 DOM?
前端·javascript·架构
Gogo11214 小时前
JavaScript 里的“空”:Null 与 Undefined 的终极指南
javascript
用户6802659051194 小时前
全栈可观测性白皮书——实施、收益与投资回报率
javascript·后端·面试
掘金安东尼4 小时前
⏰前端周刊第 454 期(2026年2月16日-2月22日)
前端·javascript·面试
掘金安东尼5 小时前
⏰前端周刊第 453 期(2026年2月9日-2月15日)
前端·javascript·面试