OdbcCommandBuilder OdbcCommandBuilder OdbcCommandBuilder OdbcCommandBuilder Class

Определение

Автоматически генерирует однотабличные команды, которые позволяют согласовать изменения, вносимые в объект DataSet, со связанным источником данных.Automatically generates single-table commands that are used to reconcile changes made to a DataSet with the associated data source. Этот класс не наследуется.This class cannot be inherited.

public ref class OdbcCommandBuilder sealed : System::Data::Common::DbCommandBuilder
public sealed class OdbcCommandBuilder : System.Data.Common.DbCommandBuilder
type OdbcCommandBuilder = class
    inherit DbCommandBuilder
Public NotInheritable Class OdbcCommandBuilder
Inherits DbCommandBuilder
Наследование

Примеры

В следующем примере используется OdbcCommandвместе с OdbcDataAdapter и OdbcConnectionдля выбора строк из источника данных.The following example uses OdbcCommand, together with OdbcDataAdapter and OdbcConnection, to select rows from a data source. В примере передается инициализированный DataSet, строка подключения, строка запроса, которая является инструкцией SQL SELECT, и строка, которая является именем таблицы источника данных.The example is passed an initialized DataSet, a connection string, a query string that is an SQL SELECT statement, and a string that is the name of the data source table. Затем в примере создается объект OdbcCommandBuilder.The example then creates an OdbcCommandBuilder.

public static DataSet SelectOdbcSrvRows(string connectionString,
    string queryString, string tableName)
{
    DataSet dataSet = new DataSet();
    using (OdbcConnection connection = new OdbcConnection(connectionString))
    {
        OdbcDataAdapter adapter = new OdbcDataAdapter();
        adapter.SelectCommand =
            new OdbcCommand(queryString, connection);
        OdbcCommandBuilder builder =
            new OdbcCommandBuilder(adapter);

        connection.Open();

        adapter.Fill(dataSet, tableName);

        //code to modify data in DataSet here

        //Without the OdbcCommandBuilder this line would fail
        adapter.Update(dataSet, tableName);
    }
    return dataSet;
}
Public Function SelectOdbcSrvRows( _
    ByVal connectionString As String, ByVal queryString As String, _
    ByVal tableName As String) As DataSet

    Dim dataSet As New DataSet()

    Using connection As New OdbcConnection(connectionString)
        Dim adapter As New OdbcDataAdapter()
        adapter.SelectCommand = _
            New OdbcCommand(queryString, connection)
        Dim builder As New OdbcCommandBuilder(adapter)

        connection.Open()

        adapter.Fill(dataSet, tableName)

        ' Code to modify data in DataSet here 

        ' Without the OdbcCommandBuilder this line would fail.
        adapter.Update(dataSet, tableName)
    End Using

    Return dataSet
End Function

Комментарии

Не создает автоматически инструкции SQL, необходимые для согласования изменений, внесенных в объект DataSet , связанный с источником данных. OdbcDataAdapterThe OdbcDataAdapter does not automatically generate the SQL statements required to reconcile changes made to a DataSet associated with the data source. Однако можно создать OdbcCommandBuilder объект, который формирует инструкции SQL для однотабличных обновлений, SelectCommand задав свойство объекта OdbcDataAdapter.However, you can create an OdbcCommandBuilder object that generates SQL statements for single-table updates by setting the SelectCommand property of the OdbcDataAdapter. OdbcCommandBuilder Затем создает все дополнительные инструкции SQL, которые не заданы.The OdbcCommandBuilder then generates any additional SQL statements that you do not set.

Отношение между OdbcDataAdapter и соответствующим OdbcCommandBuilder ему всегда равно «один к одному».The relationship between an OdbcDataAdapter and its corresponding OdbcCommandBuilder is always one-to-one. Для создания этой корреспонденции задается OdbcDataAdapter свойство OdbcCommandBuilder объекта.To create this correspondence, you set the OdbcDataAdapter property of the OdbcCommandBuilder object. Это приводит к OdbcCommandBuilder тому, что объект регистрируется в качестве прослушивателя, который RowUpdating создает выходные данные событий DataSet, влияющих на.This causes the OdbcCommandBuilder to register itself as a listener, which produces the output of RowUpdating events that affect the DataSet.

Чтобы создать инструкции INSERT, UPDATE или DELETE, OdbcCommandBuilder SelectCommand компонент использует свойство для получения требуемого набора метаданных.To generate INSERT, UPDATE, or DELETE statements, the OdbcCommandBuilder uses the SelectCommand property to retrieve a required set of metadata. Если изменить значение SelectCommand после получения метаданных, например после первого обновления, следует RefreshSchema вызвать метод для обновления метаданных.If you change the value of SelectCommand after the metadata has been retrieved, such as after the first update, you should then call the RefreshSchema method to update the metadata.

Примечание

Если в инструкции SELECT, назначенной SelectCommand свойству, используются имена столбцов с псевдонимами, то результирующие инструкции INSERT, Update и DELETE могут быть неточными или неудачными.If the SELECT statement assigned to the SelectCommand property uses aliased column names, the resulting INSERT, UPDATE, and DELETE statements may be inaccurate or fail. Если базовый драйвер ODBC не может предоставить соответствующее имя базового столбца для имени столбца псевдонима (с использованием значения SQLColAttributeSQL_DESC_BASE_COLUMN_NAME), имя псевдонима можно использовать в созданных инструкциях INSERT, Update и DELETE.If the underlying ODBC driver cannot provide the appropriate base column name for the alias column name (using the SQL_DESC_BASE_COLUMN_NAME value of SQLColAttribute), the alias name could be used in the generated INSERT, UPDATE, and DELETE statements. Например, драйвер Microsoft ODBC для Oracle возвращает псевдоним в качестве имени базового столбца.For example, the Microsoft ODBC Driver for Oracle returns the alias name as the base column name. Поэтому созданные инструкции INSERT, UPDATE и DELETE приведут к ошибкам.Therefore, the generated INSERT, UPDATE, and DELETE statements would cause errors.

В OdbcCommandBuilder CommandTimeoutтакже SelectCommandиспользуются свойства Connection, и Transaction , на которые ссылается.The OdbcCommandBuilder also uses the Connection, CommandTimeout, and Transaction properties referenced by the SelectCommand. Пользователь должен вызвать RefreshSchema , если одно или несколько из этих свойств изменяются, или значение SelectCommand самого свойства изменяется.The user should call RefreshSchema if one or more of these properties are modified, or if the value of the SelectCommand property itself is changed. В противном UpdateCommandслучае свойства DeleteCommand,и сохраняют свои предыдущие значения. InsertCommandOtherwise the InsertCommand, UpdateCommand, and DeleteCommand properties retain their previous values.

При вызове Disposeметод OdbcCommandBuilder не связывается с ,асозданныекомандыбольшенеиспользуются.OdbcDataAdapterIf you call Dispose, the OdbcCommandBuilder is disassociated from the OdbcDataAdapter, and the generated commands are no longer used.

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

OdbcCommandBuilder() OdbcCommandBuilder() OdbcCommandBuilder() OdbcCommandBuilder()

Инициализирует новый экземпляр класса OdbcCommandBuilder.Initializes a new instance of the OdbcCommandBuilder class.

OdbcCommandBuilder(OdbcDataAdapter) OdbcCommandBuilder(OdbcDataAdapter) OdbcCommandBuilder(OdbcDataAdapter) OdbcCommandBuilder(OdbcDataAdapter)

Инициализирует новый экземпляр класса OdbcCommandBuilder вместе со связанным объектом OdbcDataAdapter.Initializes a new instance of the OdbcCommandBuilder class with the associated OdbcDataAdapter object.

Свойства

CanRaiseEvents CanRaiseEvents CanRaiseEvents CanRaiseEvents

Возвращает значение, показывающее, может ли компонент вызывать событие.Gets a value indicating whether the component can raise an event.

(Inherited from Component)
Container Container Container Container

Возвращает контейнер IContainer, содержащий компонент Component.Gets the IContainer that contains the Component.

(Inherited from Component)
DataAdapter DataAdapter DataAdapter DataAdapter

Возвращает или задает объект OdbcDataAdapter, для которого данный объект OdbcCommandBuilder будет генерировать операторы SQL.Gets or sets an OdbcDataAdapter object for which this OdbcCommandBuilder object will generate SQL statements.

DesignMode DesignMode DesignMode DesignMode

Возвращает значение, указывающее, находится ли данный компонент Component в режиме конструктора в настоящее время.Gets a value that indicates whether the Component is currently in design mode.

(Inherited from Component)
Events Events Events Events

Возвращает список обработчиков событий, которые прикреплены к этому объекту Component.Gets the list of event handlers that are attached to this Component.

(Inherited from Component)
QuotePrefix QuotePrefix QuotePrefix QuotePrefix

Возвращает или задает начальный символ или символы, используемые для работы с объектами базы данных (например, таблиц или столбцов), имена которых содержат такие символы, как пробелы или зарезервированные токены.Gets or sets the beginning character or characters to use when working with database objects (for example, tables or columns) whose names contain characters such as spaces or reserved tokens.

QuoteSuffix QuoteSuffix QuoteSuffix QuoteSuffix

Возвращает или задает конечный символ или символы, используемые для работы с объектами базы данных (например, таблиц или столбцов), имена которых содержат такие символы, как пробелы или зарезервированные токены.Gets or sets the ending character or characters to use when working with database objects, (for example, tables or columns), whose names contain characters such as spaces or reserved tokens.

Site Site Site Site

Возвращает или задает ISite объекта Component.Gets or sets the ISite of the Component.

(Inherited from Component)

Методы

CreateObjRef(Type) CreateObjRef(Type) CreateObjRef(Type) CreateObjRef(Type)

Создает объект, который содержит всю необходимую информацию для создания прокси-сервера, используемого для взаимодействия с удаленным объектом.Creates an object that contains all the relevant information required to generate a proxy used to communicate with a remote object.

(Inherited from MarshalByRefObject)
DeriveParameters(OdbcCommand) DeriveParameters(OdbcCommand) DeriveParameters(OdbcCommand) DeriveParameters(OdbcCommand)

Извлекает сведения о параметрах из хранимой процедуры, указанной в объекте OdbcCommand, и включает их в коллекцию параметров Parameters указанного объекта OdbcCommand.Retrieves parameter information from the stored procedure specified in the OdbcCommand and populates the Parameters collection of the specified OdbcCommand object.

Dispose() Dispose() Dispose() Dispose()

Освобождает все ресурсы, занятые модулем Component.Releases all resources used by the Component.

(Inherited from Component)
Dispose(Boolean) Dispose(Boolean) Dispose(Boolean) Dispose(Boolean)

Освобождает неуправляемые ресурсы, используемые объектом Component, а при необходимости освобождает также управляемые ресурсы.Releases the unmanaged resources used by the Component and optionally releases the managed resources.

(Inherited from Component)
Equals(Object) Equals(Object) Equals(Object) Equals(Object)

Определяет, равен ли заданный объект текущему объекту.Determines whether the specified object is equal to the current object.

(Inherited from Object)
GetDeleteCommand() GetDeleteCommand() GetDeleteCommand() GetDeleteCommand()

Возвращает автоматически созданный объект OdbcCommand, который требуется для выполнения операций удаления в источнике данных.Gets the automatically generated OdbcCommand object required to perform deletions at the data source.

GetDeleteCommand(Boolean) GetDeleteCommand(Boolean) GetDeleteCommand(Boolean) GetDeleteCommand(Boolean)

Возвращает автоматически созданный объект OdbcCommand, который требуется для выполнения операций удаления в источнике данных.Gets the automatically generated OdbcCommand object required to perform deletions at the data source.

GetHashCode() GetHashCode() GetHashCode() GetHashCode()

Служит хэш-функцией по умолчанию.Serves as the default hash function.

(Inherited from Object)
GetInsertCommand() GetInsertCommand() GetInsertCommand() GetInsertCommand()

Возвращает автоматически созданный объект OdbcCommand, который требуется для выполнения операций вставки в источнике данных.Gets the automatically generated OdbcCommand object required to perform insertions at the data source.

GetInsertCommand(Boolean) GetInsertCommand(Boolean) GetInsertCommand(Boolean) GetInsertCommand(Boolean)

Возвращает автоматически созданный объект OdbcCommand, который требуется для выполнения операций вставки в источнике данных.Gets the automatically generated OdbcCommand object required to perform insertions at the data source.

GetLifetimeService() GetLifetimeService() GetLifetimeService() GetLifetimeService()

Извлекает объект обслуживания во время существования, который управляет политикой времени существования данного экземпляра.Retrieves the current lifetime service object that controls the lifetime policy for this instance.

(Inherited from MarshalByRefObject)
GetService(Type) GetService(Type) GetService(Type) GetService(Type)

Возвращает объект, представляющий службу, обеспечиваемую компонентом Component или его контейнером Container.Returns an object that represents a service provided by the Component or by its Container.

(Inherited from Component)
GetType() GetType() GetType() GetType()

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

(Inherited from Object)
GetUpdateCommand() GetUpdateCommand() GetUpdateCommand() GetUpdateCommand()

Возвращает автоматически созданный объект OdbcCommand, который требуется для выполнения операций обновления в источнике данных.Gets the automatically generated OdbcCommand object required to perform updates at the data source.

GetUpdateCommand(Boolean) GetUpdateCommand(Boolean) GetUpdateCommand(Boolean) GetUpdateCommand(Boolean)

Возвращает автоматически созданный объект OdbcCommand, который требуется для выполнения операций обновления в источнике данных.Gets the automatically generated OdbcCommand object required to perform updates at the data source.

InitializeLifetimeService() InitializeLifetimeService() InitializeLifetimeService() InitializeLifetimeService()

Получает объект службы времени существования для управления политикой времени существования для этого экземпляра.Obtains a lifetime service object to control the lifetime policy for this instance.

(Inherited from MarshalByRefObject)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

Создает неполную копию текущего объекта Object.Creates a shallow copy of the current Object.

(Inherited from Object)
MemberwiseClone(Boolean) MemberwiseClone(Boolean) MemberwiseClone(Boolean) MemberwiseClone(Boolean)

Создает неполную копию текущего объекта MarshalByRefObject.Creates a shallow copy of the current MarshalByRefObject object.

(Inherited from MarshalByRefObject)
QuoteIdentifier(String) QuoteIdentifier(String) QuoteIdentifier(String) QuoteIdentifier(String)

При заданном идентификаторе без кавычек в каталоге, набранном в правильном регистре, возвращает заключенный в кавычки идентификатор в корректной форме.Given an unquoted identifier in the correct catalog case, returns the correct quoted form of that identifier. При этом корректно исключаются встроенные в идентификатор кавычки.This includes correctly escaping any embedded quotes in the identifier.

QuoteIdentifier(String, OdbcConnection) QuoteIdentifier(String, OdbcConnection) QuoteIdentifier(String, OdbcConnection) QuoteIdentifier(String, OdbcConnection)

При заданном идентификаторе без кавычек в каталоге, набранном в правильном регистре, возвращает заключенный в кавычки идентификатор в корректной форме.Given an unquoted identifier in the correct catalog case, returns the correct quoted form of that identifier. При этом корректно исключаются встроенные в идентификатор кавычки.This includes correctly escaping any embedded quotes in the identifier.

RefreshSchema() RefreshSchema() RefreshSchema() RefreshSchema()

Очищает команды, связанные с этим объектом OdbcCommandBuilder.Clears the commands associated with this OdbcCommandBuilder.

ToString() ToString() ToString() ToString()

Возвращает объект String, содержащий имя Component, если оно есть.Returns a String containing the name of the Component, if any. Этот метод не следует переопределять.This method should not be overridden.

(Inherited from Component)
UnquoteIdentifier(String) UnquoteIdentifier(String) UnquoteIdentifier(String) UnquoteIdentifier(String)

Если идентификатор заключен в кавычки, возвращает правильную форму этого идентификатора без кавычек, при этом корректно учитываются кавычки, внедренные в идентификатор.Given a quoted identifier, returns the correct unquoted form of that identifier, including correctly unescaping any embedded quotes in the identifier.

UnquoteIdentifier(String, OdbcConnection) UnquoteIdentifier(String, OdbcConnection) UnquoteIdentifier(String, OdbcConnection) UnquoteIdentifier(String, OdbcConnection)

Если идентификатор заключен в кавычки, возвращает правильную форму этого идентификатора без кавычек, при этом корректно учитываются кавычки, внедренные в идентификатор.Given a quoted identifier, returns the correct unquoted form of that identifier, including correctly unescaping any embedded quotes in the identifier.

События

Disposed Disposed Disposed Disposed

Происходит при удалении компонента вызовом метода Dispose().Occurs when the component is disposed by a call to the Dispose() method.

(Inherited from Component)

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

Дополнительно