Este artículo se tradujo de forma manual. Mueva el puntero sobre las frases del artículo para ver el texto original.
Traducción
Original
Este tema aún no ha recibido ninguna valoración - Valorar este tema

DataRelation (Clase)

Representa una relación primaria-secundaria entre dos objetos DataTable.

System.Object
  System.Data.DataRelation

Espacio de nombres:  System.Data
Ensamblado:  System.Data (en System.Data.dll)
public class DataRelation

El tipo DataRelation expone los siguientes miembros.

  Nombre Descripción
Método público Compatible con XNA Framework DataRelation(String, DataColumn, DataColumn) Inicializa una nueva instancia de la clase DataRelation mediante el nombre DataRelation especificado y los objetos DataColumn primarios y secundarios.
Método público Compatible con XNA Framework DataRelation(String, DataColumn[], DataColumn[]) Inicializa una nueva instancia de la clase DataRelation mediante el nombre DataRelation especificado y las matrices coincidentes de los objetos DataColumn primarios y secundarios.
Método público Compatible con XNA Framework DataRelation(String, DataColumn, DataColumn, Boolean) Inicializa una nueva instancia de la clase DataRelation utilizando el nombre especificado, los objetos DataColumn primarios y secundarios y un valor que indica si se van a crear restricciones.
Método público Compatible con XNA Framework DataRelation(String, DataColumn[], DataColumn[], Boolean) Inicializa una nueva instancia de la clase DataRelation utilizando el nombre especificado, matrices coincidentes de objetos DataColumn primarios y secundarios y un valor que indica si se van a crear restricciones.
Método público Compatible con XNA Framework DataRelation(String, String, String, String[], String[], Boolean) Este constructor proporciona compatibilidad en tiempo de diseño en el entorno de Visual Studio.
Método público DataRelation(String, String, String, String, String, String[], String[], Boolean) Este constructor proporciona compatibilidad en tiempo de diseño en el entorno de Visual Studio.
Arriba
  Nombre Descripción
Propiedad pública Compatible con XNA Framework ChildColumns Obtiene los objetos DataColumn secundarios de esta relación.
Propiedad pública Compatible con XNA Framework ChildKeyConstraint Obtiene el ForeignKeyConstraint para la relación.
Propiedad pública Compatible con XNA Framework ChildTable Obtiene la tabla secundaria de esta relación.
Propiedad pública Compatible con XNA Framework DataSet Obtiene el DataSet al que pertenece el DataRelation.
Propiedad pública Compatible con XNA Framework ExtendedProperties Obtiene la colección que almacena propiedades personalizadas.
Propiedad pública Compatible con XNA Framework Nested Obtiene o establece un valor que indica si se anidan objetos DataRelation.
Propiedad pública Compatible con XNA Framework ParentColumns Obtiene una matriz de objetos DataColumn que son las columnas primarias de este DataRelation.
Propiedad pública Compatible con XNA Framework ParentKeyConstraint Obtiene el objeto UniqueConstraint que garantiza que los valores de la columna primaria de un objeto DataRelation son únicos.
Propiedad pública Compatible con XNA Framework ParentTable Obtiene el DataTable primario de DataRelation.
Propiedad pública Compatible con XNA Framework RelationName Obtiene o establece el nombre utilizado para recuperar un DataRelation de DataRelationCollection.
Arriba
  Nombre Descripción
Método protegido Compatible con XNA Framework CheckStateForProperty Infraestructura. Este método es compatible con la infraestructura de .NET Framework y no está pensado para utilizarlo directamente desde el código.
Método público Compatible con XNA Framework Equals(Object) Determina si el objeto Object especificado es igual al objeto Object actual. (Se hereda de Object).
Método protegido Compatible con XNA Framework Finalize Permite que un objeto intente liberar recursos y realizar otras operaciones de limpieza antes de ser reclamado por la recolección de elementos no utilizados. (Se hereda de Object).
Método público Compatible con XNA Framework GetHashCode Actúa como función hash para un tipo concreto. (Se hereda de Object).
Método público Compatible con XNA Framework GetType Obtiene el objeto Type de la instancia actual. (Se hereda de Object).
Método protegido Compatible con XNA Framework MemberwiseClone Crea una copia superficial del objeto Object actual. (Se hereda de Object).
Método protegido Compatible con XNA Framework OnPropertyChanging Este miembro es compatible con la infraestructura de .NET Framework y no está diseñado para utilizarse directamente desde el código.
Método protegido Compatible con XNA Framework RaisePropertyChanging Este miembro es compatible con la infraestructura de .NET Framework y no se debe utilizar directamente del código.
Método público Compatible con XNA Framework ToString Obtiene el RelationName, si existe alguno. (Invalida a Object.ToString()).
Arriba

El control DataRelation se utiliza para relacionar dos objetos DataTable entre sí a mediante objetos DataColumn. Por ejemplo, en una relación Customer/Orders, la tabla Customers es el elemento primario y la tabla Orders el secundario. Es similar a una relación entre la clave principal y la clave externa. Para obtener más información, vea Navegar por DataRelations (ADO.NET).

Las relaciones se crean entre columnas coincidentes de las tablas primarias y secundarias. Es decir, el valor DataType para ambas columnas debe ser idéntico.

Las relaciones también pueden originar varios cambios en cascada desde el DataRow primario hasta sus filas secundarias. Para controlar el cambio de valores en las filas secundarias, agregue un ForeignKeyConstraint al ConstraintCollection del objeto DataTable. ConstraintCollection determina la acción que se debe realizar cuando se elimina o actualiza un valor de una tabla primaria.

Cuando se crea un DataRelation, primero se comprueba que se puede establecer la relación. Después de agregarlo al DataRelationCollection, se mantiene la relación al no permitir ningún cambio que la invalide. Entre el período en que se crea un DataRelation y en que se agrega al DataRelationCollection, se pueden realizar cambios adicionales en las filas primarias o secundarias. Si esto produce una relación que ya no es válida, se genera una excepción.

Nota Nota

Pueden dañarse los datos si se define una relación bidireccional entre dos tablas. Una relación bidireccional consta de dos objetos DataRelation que usan las mismas columnas, con las funciones primarias y secundarias intercambiadas. No se produce ninguna excepción al guardar los objetos DataRelation; no obstante, pueden dañarse los datos.

Los objetos DataRelation se incluyen en un DataRelationCollection, al que se puede obtener acceso mediante la propiedad Relations del DataSet; y las propiedades ChildRelations y ParentRelations del DataTable.

En el ejemplo siguiente se crea un nuevo DataRelation y se agrega al DataRelationCollection de un DataSet.


private void CreateRelation() 
{
    // Get the DataColumn objects from two DataTable objects 
    // in a DataSet. Code to get the DataSet not shown here.
    DataColumn parentColumn = 
        DataSet1.Tables["Customers"].Columns["CustID"];
    DataColumn childColumn = 
        DataSet1.Tables["Orders"].Columns["CustID"];
    // Create DataRelation.
    DataRelation relCustOrder;
    relCustOrder = new DataRelation("CustomersOrders", 
        parentColumn, childColumn);
    // Add the relation to the DataSet.
    DataSet1.Relations.Add(relCustOrder);
}


.NET Framework

Compatible con: 4, 3.5, 3.0, 2.0, 1.1, 1.0

.NET Framework Client Profile

Compatible con: 4, 3.5 SP1

Windows 7, Windows Vista SP1 o posterior, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008 (no se admite Server Core), Windows Server 2008 R2 (se admite Server Core con SP1 o posterior), Windows Server 2003 SP2

.NET Framework no admite todas las versiones de todas las plataformas. Para obtener una lista de las versiones compatibles, vea Requisitos de sistema de .NET Framework.

Este tipo es seguro para operaciones de lectura multiproceso. Debe sincronizar cualquier operación de escritura.

¿Le ha resultado útil?
(Caracteres restantes: 1500)
Contenido de la comunidad Agregar