DbContext.SaveChanges();不会';t给出错误,但不将实体添加到数据库中
本文关键字:实体 添加 数据库 错误 出错 SaveChanges 不会 DbContext | 更新日期: 2023-09-27 18:20:56
我正试图使用以下代码将一个实体保存到我的数据库中:
public void Add(object entity)
{
DbContext.Entry(entity).State = System.Data.EntityState.Added;
DbContext.SaveChanges();
}
我测试了一下,如果有什么问题(例如,实体的一个字段为null,但在数据库中不能为null),就会出现错误。我填写了所有必要的字段并调用了此代码。它没有给出错误。然而,该实体也没有被添加到数据库中。如何查找DbContext.SaveChanges();在没有错误消息的情况下出错?
下面是调用Add()函数的代码。
public void StoreElectronicSignatureType(ElectronicSignatureTypeModel model)
{
var RSA = new System.Security.Cryptography.RSACryptoServiceProvider();
var parameters = RSA.ExportParameters(false);
model.modulus = Convert.ToBase64String(parameters.Modulus);
model.exponent = Convert.ToBase64String(parameters.Exponent);
model.privatekey = RSA.ToXmlString(true);
ElectronicSignatureType electronicSignatureType = new ElectronicSignatureType();
Entity entity = GetEntity(model.entity);
electronicSignatureType.Entity = entity;
electronicSignatureType.HashAlgorithm = model.hashAlgorithm;
electronicSignatureType.Exponent = model.exponent;
electronicSignatureType.Modulus = model.modulus;
electronicSignatureType.Version = model.version;
//electronicSignatureType.EntityId = entity.EntityId;
electronicSignatureType.PrivateKey = StrToByteArray(model.privatekey);
Add(electronicSignatureType);
}
您必须将新实体附加到上下文。尝试:
context.ElectronicSignatureTypes.Add(electronicSignatureType);
context.SaveChanges();