在Azure搜索上创建CosmosDb数据源

问题描述 投票:0回答:3

我们正尝试在Azure Search中创建一个CosmosDb数据源,以便稍后使用索引器连接到它。

但是,在尝试创建数据源时,我收到一条没有代码的神秘错误消息:

{
    "error": {
        "code": "",
        "message": "The request is invalid. Details: dataSource : Cannot create an abstract class.\r\n"
    }
}

这是发送到azure搜索的PUT请求(api-key和连接字符串已经验证为正确):

{
    "name": "datasourceName",
    "description": "Data source on CosmosDb collection x and partition y",
    "type": "documentdb",
    "credentials": {
        "connectionString": "***"
    },
    "container": {
        "name": "collectionName",
        "query": "SELECT * FROM c WHERE c.Culture = 'y' AND c.Id LIKE 'prefix%'"
    },
    "dataChangeDetectionPolicy": {
        "highWaterMarkColumnName": "_ts"
    }
}

用于该请求的URL是:

https://<servicename>.windows.net/datasources/<datasourceName>?api-version=2017-11-11-Preview

我在文档中找不到有关创建数据源响应的任何内容,欢迎提供一些指导。

问候

azure-search
3个回答
0
投票

您需要将OData type包含在更改检测策略中:

{ “@ odata.type”:“#Microsoft.Azure.Search.HighWaterMarkChangeDetectionPolicy”, “highWaterMarkColumnName”:“[行版本或最后更新列名]” }


0
投票

dataChangeDetectionPolicy请求中删除post,这是Abstract base class for data change detection policies

另外正如Carey MacDonald所说,在connectionString,不要忘记添加Database部分。

这是快照:enter image description here


0
投票

感谢大家的回复。

为了与问题保持一致(PUT而不是POST请求)我发布了答案,因为它是来自之前答案和评论的反馈组合。

所以添加后:

"@odata.type" : "#Microsoft.Azure.Search.HighWaterMarkChangeDetectionPolicy"

dataChangeDetectionPolicy json对象(当向Azure搜索发送PUT请求时)和在connectionString中添加Database部分后,它现在可以工作。

问候

© www.soinside.com 2019 - 2024. All rights reserved.