C# 尝试在数据库中保存时System.InvalidOperationException
我正在使用Oracle数据库使用Entity Framework。我试图做的是使用旧实体作为基础来保存一个新实体。我将旧实体的所有属性都带到新实体,目的是避免实体重复或多次引用的问题 我在做这样的事情:C# 尝试在数据库中保存时System.InvalidOperationException,c#,entity-framework,C#,Entity Framework,我正在使用Oracle数据库使用Entity Framework。我试图做的是使用旧实体作为基础来保存一个新实体。我将旧实体的所有属性都带到新实体,目的是避免实体重复或多次引用的问题 我在做这样的事情: List < PPL_FAMILIAR_RESPONSABLE > familiares = new List < PPL_FAMILIAR_RESPONSABLE > (); foreach(PPL_FAMILIAR_RESPONSABLE fr in registro
List < PPL_FAMILIAR_RESPONSABLE > familiares = new List < PPL_FAMILIAR_RESPONSABLE > ();
foreach(PPL_FAMILIAR_RESPONSABLE fr in registro.PPL_FAMILIAR_RESPONSABLE) {
familiares.Add(new PPL_FAMILIAR_RESPONSABLE {
FR_NOMBRE = fr.FR_NOMBRE,
FR_APPATERNO = fr.FR_APPATERNO,
FR_APMATERNO = fr.FR_APMATERNO,
PARENTESCO = fr.PARENTESCO,
COLONIA = fr.COLONIA,
CALLE = fr.CALLE,
FR_SEXO = fr.FR_SEXO,
NUMERO_EXT = fr.NUMERO_EXT,
NUMERO_INT = fr.NUMERO_INT
});
}
List < PPL_ALIAS > alias = new List < PPL_ALIAS > ();
foreach(PPL_ALIAS a in registro.PPL_ALIAS) {
alias.Add(new PPL_ALIAS {
NOMBRE_ALIAS = a.NOMBRE_ALIAS,
APPATERNO_ALIAS = a.APPATERNO_ALIAS,
APMATERNO_ALIAS = a.APMATERNO_ALIAS
});
}
List < PPL_APODO > apodos = new List < PPL_APODO > ();
foreach(PPL_APODO a in registro.PPL_APODO) {
apodos.Add(new PPL_APODO {
APODO = a.APODO,
});
}
List < PPL_PANDILLA > pandillas = new List < PPL_PANDILLA > ();
foreach(PPL_PANDILLA p in registro.PPL_PANDILLA) {
pandillas.Add(new PPL_PANDILLA {
NOTAS = p.NOTAS,
CAT_PANDILLA = p.CAT_PANDILLA,
});
}
List < PPL_RELACIONES_PERSONALES > relaciones = new List < PPL_RELACIONES_PERSONALES > ();
foreach(PPL_RELACIONES_PERSONALES rp in registro.PPL_RELACIONES_PERSONALES) {
relaciones.Add(new PPL_RELACIONES_PERSONALES {
RP_NOMBRE = rp.RP_NOMBRE,
RP_APMATERNO = rp.RP_APMATERNO,
RP_APPATERNO = rp.RP_APPATERNO,
PARENTESCO = rp.PARENTESCO,
NOTAS = rp.NOTAS
});
}
List < PPL_PERTENENCIAS > pertenencias = new List < PPL_PERTENENCIAS > ();
foreach(PPL_PERTENENCIAS p in registro.PPL_PERTENENCIAS) {
pertenencias.Add(new PPL_PERTENENCIAS {
PERTENENCIA = p.PERTENENCIA,
DESCRIPCION = p.DESCRIPCION
});
}
PPL_REGISTRO r = new PPL_REGISTRO {
AUTORIDAD_DISPOSICION = registro.AUTORIDAD_DISPOSICION,
AUTORIDAD_INTERNADO = registro.AUTORIDAD_INTERNADO,
CLASIFICACION = registro.CLASIFICACION,
EDIFICIO = registro.EDIFICIO,
ESTATUS_ADMINISTRATIVOS = registro.ESTATUS_ADMINISTRATIVOS,
FECHA_INGRESO = registro.FECHA_INGRESO,
FECHA_REGISTRO = registro.FECHA_REGISTRO,
NUM_OFICIO = registro.NUM_OFICIO,
TIPO_INGRESO = registro.TIPO_INGRESO,
TIPO_SEGURIDAD = registro.TIPO_SEGURIDAD,
UBICACION = registro.UBICACION,
DELITO = registro.DELITO,
PPL_DATOS_GENERALES = registro.PPL_DATOS_GENERALES,
PPL_PERTENENCIAS = pertenencias,
PPL_ALIAS = alias,
PPL_APODO = apodos,
PPL_FAMILIAR_RESPONSABLE = familiares,
PPL_RELACIONES_PERSONALES = relaciones,
PPL_MEDIA_FILIACION = registro.PPL_MEDIA_FILIACION,
PPL_PANDILLA = pandillas
};
using(var bl = new BLRegistroPPL()) {
bl.CrearRegistroPPL(r);
}
但在保存时,应用程序会向我抛出下一个错误:
System.InvalidOperationException:“一个实体对象不能被多个IEntityChangeTracker实例引用。”
这是什么 您发布的代码不应该是问题所在 IEntityChangeTracker的多个实例 指向另一个问题
很可能还有另一个活动的实体框架数据库上下文,它们都跟踪某个实体。有没有办法检查哪些上下文是活动的?我不知道。我想您需要检查我们的源代码和/或在创建上下文的任何地方设置断点。
public void CrearRegistroPPL(PPL_REGISTRO registroPPL) {
context.PPL_REGISTRO.Add(registroPPL);
context.SaveChanges();
}