Python 上使用 Azure Functions 的 Snowflake 外部函数无法正常工作

Snowflake External Functions using Azure Functions on Python not working

我想创建一个可用于将行更新插入 MongoDB 的外部函数。我已经创建了该函数,并在发布后使​​用 Postman 在本地对其进行了测试。我遵循了 https://docs.snowflake.com/en/sql-reference/external-functions-creating-azure-ui.html 的文档,起初,我使用了他们建议的 javascript 函数来测试和工作。但是,当我 运行 它 python 我得到一个错误。这是代码。

import logging

import azure.functions as func
import pymongo
import json
import os
from datetime import datetime

cluster = pymongo.MongoClient(os.environ['MongoDBConnString'])
db = cluster[f"{os.environ['MongoDB']}"]
collection = db[f"{os.environ['MongoDBCollection']}"]

def main(req: func.HttpRequest) -> func.HttpResponse:
    logging.info('Python HTTP trigger function processed a request.')

    name = req.params.get('name')
    if not name:
        try:
            req_body = req.get_json()
        except ValueError:
            pass
        else:
            name = req_body.get('name')

    if name:
        return func.HttpResponse(f"Hello, {name}. This HTTP triggered function executed successfully.")
    else:
        collection.update_one(
                filter={
                    '_id':req_body['_id']
                },
                update={
                    '$set': {'segment_ids': req_body['segment_ids']}
                },
                upsert=True)
        return func.HttpResponse(
                json.dumps({"status_code": 200,
                "status_message": "Upsert Success",
                "Timestamp": datetime.utcnow().strftime("%Y-%m-%dT%H:%M:%S"),
                "_id": req_body['_id']}),
                status_code=200,
                mimetype="text/plain"
        )

错误指出 req_body 在定义之前被引用,在第 '_id':req_body['_id'] 行失败。在 Snowflake 中,我创建了一个名为 mongoUpsert(body variant) 的外部函数,我正在解析一个简单的查询以进行测试。

select mongoUpsert(object_construct('_id', 'someuuid', 'segment_ids;, array_construct(1,2,3,4)))

据我所知,由于某种原因,该函数没有收到我在 Snowflake 中解析的 body。我不知道我做错了什么。谁能帮我?任何人都可以解释 Snowflake 如何发送参数(如 body、params、headers)并且有没有办法指定我是否要解析 body 或 params?

我从头开始,在 Snowflake 中一层一层地剥离。因此,Snowflake 参数被解析为函数主体,但包装在一个数组中,然后该数组又包装在另一个名为 'data' 的对象中。此外,它期望与响应返回相同的模式。下面是使用 Python.

时用于 Azure Functions 的模板
import logging
import azure.functions as func
import json

def main(req: func.HttpRequest) -> func.HttpResponse:
    # Get body response from Snowflake
    req_body = req.get_json()['data'][0][1]

    ###### Do Something
    
    # Return Response
    message = {"Task": "Completed"}
    return func.HttpResponse(
        json.dumps({'data': [[0, message]]}),
        status_code=200)

例如,我使用了一个简单的 JSON 对象:

{
  "_id": "someuuid"
}

并在 Snowflake 中创建了一个名为 testfunc(body variant) 的外部函数,并使用 select testfunc(object_construct('_id', 'someuuid')) 调用它。 如果您记录响应(使用 logging.info(req.get_json())),它将打印以下内容

{
  "data": 
  [
    [
      0,
      {
        "_id": "someuuid"
      }
    ]
  ]
}

所以为了获得我在雪花中喂食的干净输入,我有这条线

req_body = req.get_json()['data'][0][1]

但是,我一直收到响应错误,直到我尝试仅回显输入并注意到它在没有换行的情况下返回了它。返回的正文需要是一个字符串(因此为什么要使用 json.dumps()),但它也需要包装。所以要打印出来,首先定义一个你想要的消息(可能是输入的计算或者确认),然后把消息用{'data': [[0, message]]}包装起来,最后编译成字符串(json.dumps()

外部函数以特定格式发送和接收数据。所有参数都在请求体中发送。

https://docs.snowflake.com/en/sql-reference/external-functions-data-format.html

您可以结帐snowflake-labs 用于外部函数示例。

有一个专门用于 Azure Python functions 的翻译器 API。