我有一个.NET Core 3.1 API项目,使用实体框架 (Microsoft.EntityFrameworkCore.Cosmos - v3.1.5) 处理 Cosmos DB 存储。
我有一个数据库模型:
任何帮助或建议以解决此问题将不胜感激!
编辑: 对象保存到 Cosmos 是通过以下方式执行的:
我有一个数据库模型:
[JsonObject(NamingStrategyType = typeof(CamelCaseNamingStrategy))]
public class BikeRental
{
[JsonProperty(PropertyName = "id")]
[Key]
public Guid Id { get; set; }
[JsonProperty(PropertyName = "bikeId")]
public string BikeId { get; set; }
[JsonProperty(PropertyName = "shopId")]
public string ShopId { get; set; }
}
在保存到CosmosDB数据库时,列使用的是类属性名称进行序列化,忽略了“PropertyName”属性。例如,如果将“bikeId”更改为“testBikeId”,它仍然写为“BikeId”。
{
"Id": "192dfdf4-54cb-4290-a478-7035518983ca",
"BikeId": "eb65b93b-17d3-4829-9729-d48c029211fe2",
"ShopId": "636c08c4-600d-458a-98b7-8d312b8c18d2",
"_rid": "2QZIAMVYbVQBAAAAAAAAAA==",
"_self": "dbs/2QZIAA==/colls/2QZIAMVYbVQ=/docs/2QZIAMVYbVQBAAAAAAAAAA==/",
"_etag": "\"00000000-0000-0000-4627-f721b0e701d6\"",
"_attachments": "attachments/",
"_ts": 1592564051
}
任何帮助或建议以解决此问题将不胜感激!
编辑: 对象保存到 Cosmos 是通过以下方式执行的:
var response = _context.BikeRentals.Add(obj)
_context.SaveChanges();