9、使用EF Core与Azure Cosmos DB及创建客户端库

使用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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值