无法从MongoDb C#中的BsonType ObjectId反序列化字符串
本文关键字:BsonType ObjectId 反序列化 字符串 中的 MongoDb | 更新日期: 2023-09-27 18:29:58
我在C#WebAPI 中尝试从MongoDb获取所有记录时遇到错误"Cannot deserialize string from BsonType ObjectId"
我的Id是
[BsonId]
public string Id { get; set; }
更改为后
[BsonRepresentation(BsonType.ObjectId)]
public string Id { get; set; }
其工作良好的
但是当我调用post方法时,它给了我不同的错误
"'d05e139c-3a48-4213-bd89-eba0c22c3c6f' is not a valid 24 digit hex string."
如何解决这个问题
我的型号是:
public class EstablishmentDetails
{
[BsonRepresentation(BsonType.ObjectId)]
public string Id { get; set; }
public string EstablishmentName { get; set; }
public string EstablishmentType { get; set; }
public string Address { get; set; }
public string City { get; set; }
public int StateID { get; set; }
public Int32 PIN { get; set; }
public Int64 PhoneNumber { get; set; }
public string EmailID { get; set; }
public bool Published { get; set; }
public string CreatedDate { get; set; }
public string ModifiedDate { get; set; }
}
我的获取方法的存储库
public IEnumerable<EstablishmentDetails> GetAllEstablishmentDetails()
{
if (Convert.ToInt32(mCollection.Count()) > 0)
{
var EstablishmentDetailsCollection = mCollection.FindAllAs(typeof(EstablishmentDetails));
if (EstablishmentDetailsCollection.Count() > 0)
{
foreach (EstablishmentDetails item in EstablishmentDetailsCollection)
{
establishmentDetails.Add(item);
}
}
}
var results = establishmentDetails.AsQueryable();
return results;
}
我的Post方法存储库
public EstablishmentDetails Add(EstablishmentDetails ed)
{
if (string.IsNullOrEmpty(ed.Id))
{
ed.Id = Guid.NewGuid().ToString();
}
mCollection.Save(ed);
return ed;
}
而不是使用
ed.Id = Guid.NewGuid().ToString();
我使用
ed.Id = MongoDB.Bson.ObjectId.GenerateNewId().ToString();
用于生成Id
其工作状态良好:)
Guid.NewGuid()不会生成ObjectId。对象Id是12字节的数据结构,Guid生成16字节的十六进制字符串(不带'-')
您应该删除属性[BsonRepresentation(BsonType.ObjectId)]
您可以在实体中使用任何字符串作为Id,例如"HiDude"和utf8格式的任何字符串。