EntityCollection<TEntity>.Remove(TEntity) Método
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Quita un objeto de la colección y marca la relación para eliminación.
public:
virtual bool Remove(TEntity entity);
public bool Remove (TEntity entity);
override this.Remove : 'Entity -> bool
Public Function Remove (entity As TEntity) As Boolean
Parámetros
- entity
- TEntity
Objeto que se quitará de la colección.
Devoluciones
Es true
si el elemento se quitó correctamente; de lo contrario, es false
.
Implementaciones
Excepciones
El objeto entity
es null
.
El objeto entity
no está asociado al mismo contexto del objeto.
o bien
El objeto entity
no tiene un administrador de relaciones válido.
Ejemplos
Este ejemplo se basa en el modelo Adventure Works Sales. Para ejecutar el código de este ejemplo, debe haber agregado ya el modelo AdventureWorks Sales al proyecto y haber configurado el proyecto para que use Entity Framework. Para ello, complete los procedimientos descritos en How to: Manually Configure an Entity Framework Project (Cómo: Configurar manualmente un proyecto de Entity Framework ) y How to: Manually Define the Model and Mapping Files (Cómo: Definir manualmente los archivos de modelo y asignación).
En este ejemplo, se usa el método Remove para quitar una de las entidades de la colección y, a continuación, llama al método Contains para determinar si el objeto se ha quitado de la colección.
using (AdventureWorksEntities context =
new AdventureWorksEntities())
{
Contact contact = new Contact();
// Create a new SalesOrderHeader.
SalesOrderHeader newSalesOrder1 = new SalesOrderHeader();
// Add SalesOrderHeader to the Contact.
contact.SalesOrderHeaders.Add(newSalesOrder1);
// Create another SalesOrderHeader.
SalesOrderHeader newSalesOrder2 = new SalesOrderHeader();
// Add SalesOrderHeader to the Contact.
contact.SalesOrderHeaders.Add(newSalesOrder2);
// Get all related ends
IEnumerable<IRelatedEnd> relEnds =
((IEntityWithRelationships)contact)
.RelationshipManager.GetAllRelatedEnds();
foreach (IRelatedEnd relEnd in relEnds)
{
// Get Entity Collection from related end
EntityCollection<SalesOrderHeader> entityCollection =
(EntityCollection<SalesOrderHeader>)relEnd;
Console.WriteLine("EntityCollection count: {0}",
entityCollection.Count);
// Remove the first entity object.
entityCollection.Remove(newSalesOrder1);
bool contains = entityCollection.Contains(newSalesOrder1);
// Write the number of items after one entity has been removed
Console.WriteLine("EntityCollection count after one entity has been removed: {0}",
entityCollection.Count);
if (contains == false)
Console.WriteLine("The removed entity is not in in the collection any more.");
//Use IRelatedEnd to add the entity back.
relEnd.Add(newSalesOrder1);
Console.WriteLine("EntityCollection count after an entity has been added again: {0}",
entityCollection.Count);
}
}
Comentarios
El método Remove también elimina la relación entre el objeto de origen y el objeto que se va a quitar de la colección. Si la relación tiene una restricción de integridad referencial, al llamar al método Remove en un objeto dependiente, se marcan para eliminación tanto la relación como el objeto dependiente. Esto ocurre porque la restricción indica que el objeto dependiente no puede existir sin una relación con el objeto primario. Para obtener más información, vea Elemento ReferentialConstraint (CSDL).
Remove devuelve false
cuando el objeto especificado no está en la colección.