Прочитать на английском

Поделиться через


Constraint Класс

Определение

Представляет ограничение, которое может быть применено к одному или более объектам DataColumn.

[System.ComponentModel.TypeConverter(typeof(System.Data.ConstraintConverter))]
public abstract class Constraint
public abstract class Constraint
[System.ComponentModel.TypeConverter(typeof(System.Data.ConstraintConverter))]
[System.Serializable]
public abstract class Constraint
Наследование
Constraint
Производный
Атрибуты

Примеры

В следующем примере проверяется коллекция ограничений для DataTable и определяется, является ли каждое ограничение или UniqueConstraintForeignKeyConstraint. Затем отображаются свойства ограничения.

private void GetConstraints(DataTable dataTable)
{
    Console.WriteLine();

    // Print the table's name.
    Console.WriteLine("TableName: " + dataTable.TableName);

    // Iterate through the collection and
    // print each name and type value.
    foreach(Constraint constraint in dataTable.Constraints )
    {
        Console.WriteLine("Constraint Name: "
            + constraint.ConstraintName);
        Console.WriteLine("Type: "
            + constraint.GetType().ToString());

        // If the constraint is a UniqueConstraint,
        // print its properties using a function below.
        if(constraint is UniqueConstraint)
        {
            PrintUniqueConstraintProperties(constraint);
        }
        // If the constraint is a ForeignKeyConstraint,
        // print its properties using a function below.
        if(constraint is ForeignKeyConstraint)
        {
            PrintForeignKeyConstraintProperties(constraint);
        }
    }
}

private void PrintUniqueConstraintProperties(
    Constraint constraint)
{
    UniqueConstraint uniqueConstraint;
    uniqueConstraint = (UniqueConstraint) constraint;

    // Get the Columns as an array.
    DataColumn[] columnArray;
    columnArray = uniqueConstraint.Columns;

    // Print each column's name.
    for(int i = 0;i<columnArray.Length ;i++)
    {
        Console.WriteLine("Column Name: "
            + columnArray[i].ColumnName);
    }
}

private void PrintForeignKeyConstraintProperties(
    Constraint constraint)
{
    ForeignKeyConstraint fkConstraint;
    fkConstraint = (ForeignKeyConstraint) constraint;

    // Get the Columns as an array.
    DataColumn[] columnArray;
    columnArray = fkConstraint.Columns;

    // Print each column's name.
    for(int i = 0;i<columnArray.Length ;i++)
    {
        Console.WriteLine("Column Name: "
            + columnArray[i].ColumnName);
    }
    Console.WriteLine();

    // Get the related columns and print each columns name.
    columnArray = fkConstraint.RelatedColumns ;
    for(int i = 0;i<columnArray.Length ;i++)
    {
        Console.WriteLine("Related Column Name: "
            + columnArray[i].ColumnName);
    }
    Console.WriteLine();
}

Комментарии

Ограничение — это правило, используемое для поддержания целостности данных в DataTable. Например, при удалении значения, используемого в одной или нескольких связанных таблицах, ForeignKeyConstraint определяет, будут ли также удалены значения из связанных таблиц, заданы значения NULL, заданы значения по умолчанию или нет никаких действий. С UniqueConstraintдругой стороны, просто гарантирует, что все значения в определенной таблице уникальны. Дополнительные сведения см. в разделе Ограничения DataTable.

Базовый Constraint конструктор не используется. Ограничения первичного или уникального ключа создаются с помощью конструктора UniqueConstraint , а ограничения внешнего ключа — с помощью конструктора ForeignKeyConstraint .

Конструкторы

Constraint()

Инициализирует новый экземпляр класса Constraint.

Свойства

_DataSet

Возвращает объект DataSet, которому принадлежит данное ограничение.

ConstraintName

Имя ограничения в ConstraintCollection.

ExtendedProperties

Возвращает коллекцию определенных пользователем свойств ограничений.

Table

Возвращает объект DataTable, к которому применяется ограничение.

Методы

CheckStateForProperty()

Возвращает объект DataSet, которому принадлежит данное ограничение.

Equals(Object)

Определяет, равен ли указанный объект текущему объекту.

(Унаследовано от Object)
GetHashCode()

Служит хэш-функцией по умолчанию.

(Унаследовано от Object)
GetType()

Возвращает объект Type для текущего экземпляра.

(Унаследовано от Object)
MemberwiseClone()

Создает неполную копию текущего объекта Object.

(Унаследовано от Object)
SetDataSet(DataSet)

Задает объект DataSet ограничения.

ToString()

Возвращает свойство ConstraintName, если оно существует, в виде строки.

Применяется к

Потокобезопасность

Этот тип является безопасным для многопоточных операций чтения. Необходимо синхронизировать все операции записи.

См. также раздел