OdbcCommandBuilder OdbcCommandBuilder OdbcCommandBuilder OdbcCommandBuilder Class

Definição

Gera automaticamente os comandos de tabela única que são usados para reconciliar as alterações feitas em um DataSet com a fonte de dados associada.Automatically generates single-table commands that are used to reconcile changes made to a DataSet with the associated data source. Essa classe não pode ser herdada.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
Herança

Exemplos

O exemplo a seguir OdbcCommandusa, junto OdbcDataAdapter com OdbcConnectione, para selecionar linhas de uma fonte de dados.The following example uses OdbcCommand, together with OdbcDataAdapter and OdbcConnection, to select rows from a data source. O exemplo é passado como inicializado DataSet, uma cadeia de conexão, uma cadeia de caracteres de consulta que é uma instrução SQL SELECT e uma cadeia de caracteres que é o nome da tabela de fonte de dados.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. Em seguida, o exemplo OdbcCommandBuildercria um.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

Comentários

O OdbcDataAdapter não gera automaticamente as instruções SQL necessárias para reconciliar as alterações feitas em um DataSet associado à fonte de dados.The OdbcDataAdapter does not automatically generate the SQL statements required to reconcile changes made to a DataSet associated with the data source. No entanto, você pode OdbcCommandBuilder criar um objeto que gera instruções SQL para atualizações de tabela única definindo SelectCommand a propriedade do OdbcDataAdapter.However, you can create an OdbcCommandBuilder object that generates SQL statements for single-table updates by setting the SelectCommand property of the OdbcDataAdapter. Em OdbcCommandBuilder seguida, o gera quaisquer instruções SQL adicionais que você não definir.The OdbcCommandBuilder then generates any additional SQL statements that you do not set.

A relação entre um OdbcDataAdapter e seu correspondente OdbcCommandBuilder é sempre um-para-um.The relationship between an OdbcDataAdapter and its corresponding OdbcCommandBuilder is always one-to-one. Para criar essa correspondência, você define a OdbcDataAdapter propriedade OdbcCommandBuilder do objeto.To create this correspondence, you set the OdbcDataAdapter property of the OdbcCommandBuilder object. Isso faz com OdbcCommandBuilder que o registre-se como um ouvinte, que produz RowUpdating a saída de eventos DataSetque afetam o.This causes the OdbcCommandBuilder to register itself as a listener, which produces the output of RowUpdating events that affect the DataSet.

Para gerar instruções INSERT, Update ou DELETE, o OdbcCommandBuilder usa a SelectCommand propriedade para recuperar um conjunto de metadados necessário.To generate INSERT, UPDATE, or DELETE statements, the OdbcCommandBuilder uses the SelectCommand property to retrieve a required set of metadata. Se você alterar o valor de SelectCommand depois que os metadados forem recuperados, como após a primeira atualização, você deverá chamar o RefreshSchema método para atualizar os metadados.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.

Observação

Se a instrução SELECT atribuída à SelectCommand Propriedade usar nomes de coluna com alias, as instruções INSERT, Update e Delete resultantes poderão ser imprecisas ou falhar.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. Se o driver ODBC subjacente não puder fornecer o nome de coluna de base apropriado para o nome da coluna de alias ( SQLColAttributeusando o valor SQL_DESC_BASE_COLUMN_NAME de), o nome do alias poderá ser usado nas instruções INSERT, Update e Delete geradas.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. Por exemplo, o Microsoft ODBC driver for Oracle retorna o nome do alias como o nome da coluna base.For example, the Microsoft ODBC Driver for Oracle returns the alias name as the base column name. Portanto, as instruções INSERT, UPDATE e DELETE geradas causaram erros.Therefore, the generated INSERT, UPDATE, and DELETE statements would cause errors.

O OdbcCommandBuilder também usa as Connectionpropriedades CommandTimeout, e Transaction referenciadas pelo SelectCommand.The OdbcCommandBuilder also uses the Connection, CommandTimeout, and Transaction properties referenced by the SelectCommand. O usuário deve chamar RefreshSchema se uma ou mais dessas propriedades forem modificadas ou se o valor SelectCommand da propriedade for alterado.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. Caso contrário InsertCommand, UpdateCommandas propriedades DeleteCommand , e reterão seus valores anteriores.Otherwise the InsertCommand, UpdateCommand, and DeleteCommand properties retain their previous values.

Se você chamar Dispose, o OdbcCommandBuilder OdbcDataAdapterserá desassociado do, e os comandos gerados não serão mais usados.If you call Dispose, the OdbcCommandBuilder is disassociated from the OdbcDataAdapter, and the generated commands are no longer used.

Construtores

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

Inicializa uma nova instância da classe OdbcCommandBuilder.Initializes a new instance of the OdbcCommandBuilder class.

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

Inicializa uma nova instância da classe OdbcCommandBuilder com o objeto OdbcDataAdapter associado.Initializes a new instance of the OdbcCommandBuilder class with the associated OdbcDataAdapter object.

Propriedades

CanRaiseEvents CanRaiseEvents CanRaiseEvents CanRaiseEvents

Obtém um valor que indica se o componente pode acionar um evento.Gets a value indicating whether the component can raise an event.

(Inherited from Component)
Container Container Container Container

Obtém o IContainer que contém o Component.Gets the IContainer that contains the Component.

(Inherited from Component)
DataAdapter DataAdapter DataAdapter DataAdapter

Obtém ou define um objeto OdbcDataAdapter para o qual o objeto OdbcCommandBuilder gerará instruções SQL.Gets or sets an OdbcDataAdapter object for which this OdbcCommandBuilder object will generate SQL statements.

DesignMode DesignMode DesignMode DesignMode

Obtém um valor que indica se o Component está no modo de design no momento.Gets a value that indicates whether the Component is currently in design mode.

(Inherited from Component)
Events Events Events Events

Obtém a lista de manipuladores de eventos que estão anexados a este Component.Gets the list of event handlers that are attached to this Component.

(Inherited from Component)
QuotePrefix QuotePrefix QuotePrefix QuotePrefix

Obtém ou define os caracteres iniciais a serem usados ao trabalhar com objetos de banco de dados (por exemplo, tabelas ou colunas) cujos nomes contenham caracteres, como espaços ou tokens reservados.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

Obtém ou define os caracteres finais a serem usados ao trabalhar com objetos de banco de dados (por exemplo, tabelas ou colunas) cujos nomes contenham caracteres, como espaços ou tokens reservados.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

Obtém ou define o ISite do Component.Gets or sets the ISite of the Component.

(Inherited from Component)

Métodos

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

Cria um objeto que contém todas as informações relevantes necessárias para gerar um proxy usado para se comunicar com um objeto remoto.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)

Recupera informações de parâmetro do procedimento armazenado especificado no OdbcCommand e popula a coleção Parameters do objeto OdbcCommand especificado.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()

Libera todos os recursos usados pelo Component.Releases all resources used by the Component.

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

Libera os recursos não gerenciados usados pelo Component e opcionalmente libera os recursos gerenciados.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)

Determina se o objeto especificado é igual ao objeto atual.Determines whether the specified object is equal to the current object.

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

Obtém o objeto OdbcCommand gerado automaticamente necessário para realizar exclusões na fonte de dados.Gets the automatically generated OdbcCommand object required to perform deletions at the data source.

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

Obtém o objeto OdbcCommand gerado automaticamente necessário para realizar exclusões na fonte de dados.Gets the automatically generated OdbcCommand object required to perform deletions at the data source.

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

Serve como a função de hash padrão.Serves as the default hash function.

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

Obtém o objeto OdbcCommand gerado automaticamente necessário para realizar inserções na fonte de dados.Gets the automatically generated OdbcCommand object required to perform insertions at the data source.

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

Obtém o objeto OdbcCommand gerado automaticamente necessário para realizar inserções na fonte de dados.Gets the automatically generated OdbcCommand object required to perform insertions at the data source.

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

Recupera o objeto de serviço de tempo de vida atual que controla a política de ciclo de vida para esta instância.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)

Retorna um objeto que representa um serviço fornecido pelo Component ou pelo seu Container.Returns an object that represents a service provided by the Component or by its Container.

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

Obtém o Type da instância atual.Gets the Type of the current instance.

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

Obtém o objeto OdbcCommand gerado automaticamente necessário para realizar atualizações na fonte de dados.Gets the automatically generated OdbcCommand object required to perform updates at the data source.

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

Obtém o objeto OdbcCommand gerado automaticamente necessário para realizar atualizações na fonte de dados.Gets the automatically generated OdbcCommand object required to perform updates at the data source.

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

Obtém um objeto de serviço de tempo de vida para controlar a política de tempo de vida para essa instância.Obtains a lifetime service object to control the lifetime policy for this instance.

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

Cria uma cópia superficial do Object atual.Creates a shallow copy of the current Object.

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

Cria uma cópia superficial do objeto MarshalByRefObject atual.Creates a shallow copy of the current MarshalByRefObject object.

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

Dado um identificador sem aspas no caso de catálogo correto, retorna a forma entre aspas correta desse identificador.Given an unquoted identifier in the correct catalog case, returns the correct quoted form of that identifier. Isso inclui o uso da sequência de escape correta de quaisquer aspas inseridas no identificador.This includes correctly escaping any embedded quotes in the identifier.

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

Dado um identificador sem aspas no caso de catálogo correto, retorna a forma entre aspas correta desse identificador.Given an unquoted identifier in the correct catalog case, returns the correct quoted form of that identifier. Isso inclui o uso da sequência de escape correta de quaisquer aspas inseridas no identificador.This includes correctly escaping any embedded quotes in the identifier.

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

Limpa os comandos associados a este OdbcCommandBuilder.Clears the commands associated with this OdbcCommandBuilder.

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

Retorna um String que contém o nome do Component, se houver.Returns a String containing the name of the Component, if any. Esse método não deve ser substituído.This method should not be overridden.

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

Dado um identificador entre aspas, retorna a forma sem aspas correta desse identificador, incluindo desfazer corretamente o escape de quaisquer aspas inseridas no identificador.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)

Dado um identificador entre aspas, retorna a forma sem aspas correta desse identificador, incluindo desfazer corretamente o escape de quaisquer aspas inseridas no identificador.Given a quoted identifier, returns the correct unquoted form of that identifier, including correctly unescaping any embedded quotes in the identifier.

Eventos

Disposed Disposed Disposed Disposed

Ocorre quando o componente é disposto por uma chamada para o método Dispose().Occurs when the component is disposed by a call to the Dispose() method.

(Inherited from Component)

Aplica-se a

Veja também