【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


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

相关推荐
文阿花9 分钟前
Echarts实现自定旋转3D饼状图
javascript·3d·echarts·饼状图
meilindehuzi_a43 分钟前
深入理解 JavaScript 的同步与异步机制:从单线程设计到 Promise 核心应用
开发语言·javascript·ecmascript
如烟花的信页1 小时前
加速乐cookie逆向分析
javascript·爬虫·python·js逆向
永远的WEB小白1 小时前
css改变svg图标的颜色
前端·javascript·css
ikoala1 小时前
Codex 不得不装的 12 个插件,都在这了
前端·javascript·后端
赵庆明老师2 小时前
JS检查提交的文件是否合规
开发语言·前端·javascript
颂love2 小时前
Vue的两大生态以及组件通信
前端·javascript·vue.js·typescript
光影少年2 小时前
js单线程,为什在node环境下的js可以处理高并发请求?
前端·javascript·掘金·金石计划
2601_961875242 小时前
高考真题电子版|2025高考全科真题分类PDF
金融·pdf·云计算·azure·七牛云存储·交友·高考
moMo3 小时前
# JavaScript 的“等等我”:聊聊同步与异步
javascript