SqlQuery в функции Azure ARRAY_CONTAINS не работает - PullRequest
0 голосов
/ 03 января 2019

Я определил функцию в cosmo db, определенную следующим образом.В редакторе запрос работает, но когда я запускаю функцию, он возвращает 500 Внутренняя ошибка сервера .

Мой документ:

{
    "user": "428",
    "year": "2019",
    "id": "1",
    "dataType": "LineString",
    "dataCategory": "realPath",
    "tripNumber": "A02232",
    "currentCoordinate": [
        13.845224,
        43.02356
    ],
    "deliveries": [
        {
            "devNumber": "001",
            "unloadSeq": "1",
            "currentDev": "1",
            "email": "punto1@mail.it",
            "targetCoordinate": [
                13.965224,
                43.95356
            ],
            "coordinates": [
                [
                    13.790663,
                    43.028926
                ],
                [
                    13.791447,
                    43.029169
                ],
                [
                    13.792198,
                    43.029561
                ],
                [
                    13.793775,
                    43.030549
                ],
                [
                    13.794601,
                    43.0312
                ],
                [
                    13.795577,
                    43.031835
                ],
                [
                    13.797047,
                    43.032737
                ],
                [
                    13.797605,
                    43.033153
                ],
                [
                    13.798249,
                    43.033647
                ],
                [
                    13.798732,
                    43.03367
                ],
                [
                    13.800126,
                    43.033678
                ],
                [
                    13.801661,
                    43.033725
                ],
                [
                    13.802755,
                    43.034172
                ],
                [
                    13.845224,
                    43.02356
                ]
            ]
        },
        {
            "devNumber": "008",
            "unloadSeq": "2",
            "currentDev": "0",
            "email": "punto2@mail.it",
            "targetCoordinate": [
                13.995224,
                43.99356
            ],
            "coordinates": []
        }
    ],
    "_rid": "3pRjAIHZRNUBAAAAAAAAAA==",
    "_self": "dbs/3pRjAA==/colls/3pRjAIHZRNU=/docs/3pRjAIHZRNUBAAAAAAAAAA==/",
    "_etag": "\"00006b08-0000-0000-0000-5c2def460000\"",
    "_attachments": "attachments/",
    "_ts": 1546514246
}

Запрос в редакторе это нормально:

SELECT * FROM Trip c where ARRAY_CONTAINS(c.deliveries, {"currentDev": "1", "email": "punto1@mail.it"}, true)

Запрос в function.json не работает:

{
  "bindings": [
    {
      "authLevel": "function",
      "name": "req",
      "type": "httpTrigger",
      "direction": "in",
      "methods": [
        "get",
        "post"
      ],
      "route": "getRoutes/{emailpar}"
    },
    {
      "name": "$return",
      "type": "http",
      "direction": "out"
    },
    {
      "type": "cosmosDB",
      "name": "inDocuments",
      "databaseName": "cdb-01",
      "collectionName": "myCollection",
      "connectionStringSetting": "mpn_COSMOSDB",
      "direction": "in",
      "sqlQuery": "SELECT * FROM Trip c where ARRAY_CONTAINS(c.deliveries, {currentDev: '1', email: {emailpar}}, true)"
    }
  ]
}

Я думаю, что это проблема синтаксиса для определения параметра и объекта, который нужно искать в массиве через скобки {}.

1 Ответ

0 голосов
/ 03 января 2019

Вам необходимо экранировать интерполированный объект без параметра строки строки запроса sql. Вы можете сделать это, добавив дополнительную фигурную скобку в каждую ссылку.

Это означает, что ваша строка запроса должна быть:

SELECT * FROM Trip c where ARRAY_CONTAINS(c.deliveries, {{currentDev: '1', email: {emailpar}}}, true)

...