Я настраиваю Polybase для Azure CosmosDB (MongoDB API) на SQL Server 2019, и я застрял при создании внешней таблицы.
Я создал один образец документа в Cosmos DB со следующим определением :
{
"_id" : ObjectId("5ecc3fcd7791b617982fefa0"),
"id" : "1",
"products" : "2009",
"item" : "Car",
"type" : "Racecar"
}
Отрезано с портала Azure для сбора образцов
Когда я запускаю следующий оператор:
CREATE EXTERNAL TABLE mongodb.Products
(
[_id] NVARCHAR(24) COLLATE Latin1_General_CI_AS NOT NULL,
[id] NVARCHAR(10) COLLATE Latin1_General_CI_AS,
[products] NVARCHAR(10) COLLATE Latin1_General_CI_AS,
[item] NVARCHAR(10) COLLATE Latin1_General_CI_AS,
[type] NVARCHAR(10) COLLATE Latin1_General_CI_AS
)
WITH (
LOCATION='Sales.Products',
DATA_SOURCE= CosmosDB
);
Я получаю сообщение :
Msg 105083, Level 16, State 1, Line 1
105083;The following columns in the user defined schema are incompatible with the external table schema for table 'Products': user defined column: 'id' was not found in the external table, user defined column: 'products' was not found in the external table, user defined column: 'item' was not found in the external table, user defined column: 'type' was not found in the external table. The detected external table schema is: ([_id] NVARCHAR(24) COLLATE Latin1_General_100_CI_AS NOT NULL).
Связь вроде в порядке. Если я изменю Sales.Product, я получу сообщение о том, что таблица не существует.