使用EF Core与Azure Cosmos DB及创建客户端库
1. 使用EF Core与Azure Cosmos DB
1.1 运行时差异
在运行时,Azure Cosmos DB 与传统 SQL 数据库有所不同。Azure Cosmos DB 提供程序不使用 SQL 的 INSERT 和 UPDATE 语句,而是执行 CreateItem 和 ReplaceItem 函数。查看日志输出时,可以看到每个操作所需的请求单位(RUs)数量。
1.2 查询示例
之前定义的 GetGamesAsync
方法同样适用于 Cosmos DB 提供程序,生成的查询如下:
SELECT c
FROM root c
WHERE (((c["Discriminator"] = "Game") AND ((c["StartTime"] < @__end_0) AND (c["StartTime"] > @__begin_1))) AND (c["GameType"] = @__gamesQuery_GameType_2))
ORDER BY c["StartTime"] DESC
OFFSET 0 LIMIT @__p_3
与 SQL Server 数据库的查询相比,Cosmos DB 的查询要简单得多,无需进行表连接。此查询中有趣的部分是对 Discriminator
的过滤。默认情况下,存储在容器中的每个对象都有一个包含类型名称的 Discriminator