OleDbCommandBuilder Classe

Definizione

Genera automaticamente comandi di tabella singola utilizzati per risolvere le modifiche apportate a una classe DataSet con il database associato.Automatically generates single-table commands that are used to reconcile changes made to a DataSet with the associated database. Questa classe non può essere ereditata.This class cannot be inherited.

public ref class OleDbCommandBuilder sealed : System::Data::Common::DbCommandBuilder
public sealed class OleDbCommandBuilder : System.Data.Common.DbCommandBuilder
type OleDbCommandBuilder = class
    inherit DbCommandBuilder
Public NotInheritable Class OleDbCommandBuilder
Inherits DbCommandBuilder
Ereditarietà
OleDbCommandBuilder

Esempi

Nell'esempio seguente vengono utilizzate le OleDbCommand, insieme OleDbDataAdapter e OleDbConnection, per selezionare le righe da un'origine dati.The following example uses the OleDbCommand, along OleDbDataAdapter and OleDbConnection, to select rows from a data source. All'esempio viene passato un DataSetinizializzato, una stringa di connessione, una stringa di query che è un'istruzione SQL SELECT e una stringa che rappresenta il nome della tabella dell'origine dati.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. Nell'esempio viene quindi creato un OleDbCommandBuilder.The example then creates an OleDbCommandBuilder.

public static DataSet UpdateRows(string connectionString,
    string queryString, string tableName)
{
    DataSet dataSet = new DataSet();
    using (OleDbConnection connection = new OleDbConnection(connectionString))
    {
        OleDbDataAdapter adapter = new OleDbDataAdapter();
        adapter.SelectCommand = new OleDbCommand(queryString, connection);
        OleDbCommandBuilder cb = new OleDbCommandBuilder(adapter);

        connection.Open();

        adapter.Fill(dataSet, tableName);

        //code to modify data in DataSet here

        cb.GetDeleteCommand();
        //Without the OleDbCommandBuilder this line would fail
        adapter.Update(dataSet, tableName);

        connection.Close();
    }
    return dataSet;
}
Public Shared Function UpdateRows(ByVal connectionString As String, _
ByVal queryString As String, ByVal tableName As String) As DataSet

    Dim dataSet As New DataSet()

    Using connection As New OleDbConnection(connectionString)
        Dim adapter As New OleDbDataAdapter()
        adapter.SelectCommand = New OleDbCommand(queryString, connection)
        Dim builder As New OleDbCommandBuilder(adapter)

        connection.Open()

        adapter.Fill(dataSet, tableName)

        ' Code to modify data in DataSet here 

        builder.GetUpdateCommand()

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

    Return dataSet
End Function

Commenti

Il OleDbDataAdapter non genera automaticamente le istruzioni SQL necessarie per riconciliare le modifiche apportate a una DataSet con l'origine dati associata.The OleDbDataAdapter does not automatically generate the SQL statements required to reconcile changes made to a DataSet with the associated data source. Tuttavia, è possibile creare un oggetto OleDbCommandBuilder per generare automaticamente istruzioni SQL per gli aggiornamenti di una singola tabella se si imposta la proprietà SelectCommand dell'OleDbDataAdapter.However, you can create an OleDbCommandBuilder object to automatically generate SQL statements for single-table updates if you set the SelectCommand property of the OleDbDataAdapter. Quindi, eventuali istruzioni SQL aggiuntive che non vengono impostate vengono generate dal OleDbCommandBuilder.Then, any additional SQL statements that you do not set are generated by the OleDbCommandBuilder.

Il OleDbCommandBuilder si registra come listener per RowUpdating eventi quando si imposta la proprietà DataAdapter.The OleDbCommandBuilder registers itself as a listener for RowUpdating events whenever you set the DataAdapter property. È possibile associare un solo OleDbDataAdapter o OleDbCommandBuilder oggetto in una sola volta.You can only associate one OleDbDataAdapter or OleDbCommandBuilder object with each other at one time.

Per generare istruzioni INSERT, UPDATE o DELETE, il OleDbCommandBuilder utilizza la proprietà SelectCommand per recuperare automaticamente un set di metadati richiesto.To generate INSERT, UPDATE, or DELETE statements, the OleDbCommandBuilder uses the SelectCommand property to retrieve a required set of metadata automatically. Se si modifica il SelectCommand dopo il recupero dei metadati, ad esempio dopo il primo aggiornamento, è necessario chiamare il metodo RefreshSchema per aggiornare i metadati.If you change the SelectCommand after the metadata is retrieved, such as after the first update, you should call the RefreshSchema method to update the metadata.

Il OleDbCommandBuilder utilizza anche le proprietà Connection, CommandTimeoute Transaction a cui fa riferimento il SelectCommand.The OleDbCommandBuilder also uses the Connection, CommandTimeout, and Transaction properties referenced by the SelectCommand. L'utente deve chiamare RefreshSchema se una o più di queste proprietà vengono modificate o se il SelectCommand stesso viene sostituito.The user should call RefreshSchema if one or more of these properties are modified, or if the SelectCommand itself is replaced. In caso contrario, le proprietà InsertCommand, UpdateCommande DeleteCommand mantengono i valori precedenti.Otherwise the InsertCommand, UpdateCommand, and DeleteCommand properties retain their previous values.

Se si chiama Dispose, l'OleDbCommandBuilder viene dissociata dalla OleDbDataAdaptere i comandi generati non vengono più utilizzati.If you call Dispose, the OleDbCommandBuilder is disassociated from the OleDbDataAdapter, and the generated commands are no longer used.

Costruttori

OleDbCommandBuilder()

Inizializza una nuova istanza della classe OleDbCommandBuilder.Initializes a new instance of the OleDbCommandBuilder class.

OleDbCommandBuilder(OleDbDataAdapter)

Inizializza una nuova istanza della classe OleDbCommandBuilder con l'oggetto OleDbDataAdapter associato.Initializes a new instance of the OleDbCommandBuilder class with the associated OleDbDataAdapter object.

Proprietà

CanRaiseEvents

Ottiene un valore che indica se il componente può generare un evento.Gets a value indicating whether the component can raise an event.

(Ereditato da Component)
CatalogLocation

Ottiene o imposta il valore CatalogLocation per un'istanza della classe DbCommandBuilder.Gets or sets the CatalogLocation for an instance of the DbCommandBuilder class.

(Ereditato da DbCommandBuilder)
CatalogSeparator

Ottiene o imposta una stringa usata come separatore di catalogo per un'istanza della classe DbCommandBuilder.Gets or sets a string used as the catalog separator for an instance of the DbCommandBuilder class.

(Ereditato da DbCommandBuilder)
ConflictOption

Specifica quale enumerazione ConflictOption deve essere utilizzata dalla classe DbCommandBuilder.Specifies which ConflictOption is to be used by the DbCommandBuilder.

(Ereditato da DbCommandBuilder)
Container

Ottiene il IContainer che contiene il Component.Gets the IContainer that contains the Component.

(Ereditato da Component)
DataAdapter

Ottiene o imposta un oggetto OleDbDataAdapter per il quale sono generate automaticamente istruzioni SQL.Gets or sets an OleDbDataAdapter object for which SQL statements are automatically generated.

DesignMode

Ottiene un valore che indica se il Component si trova in modalità progettazione.Gets a value that indicates whether the Component is currently in design mode.

(Ereditato da Component)
Events

Ottiene l'elenco dei gestori eventi allegati a questo Component.Gets the list of event handlers that are attached to this Component.

(Ereditato da Component)
QuotePrefix

Ottiene o imposta il carattere o i caratteri iniziali da utilizzare quando si specificano oggetti di database, ad esempio tabelle o colonne, i cui nomi contengono caratteri quali spazi o token riservati.Gets or sets the beginning character or characters to use when specifying database objects (for example, tables or columns) whose names contain characters such as spaces or reserved tokens.

QuoteSuffix

Ottiene o imposta il carattere o i caratteri finali da utilizzare quando si specificano oggetti di database, ad esempio tabelle o colonne, i cui nomi contengono caratteri quali spazi o token riservati.Gets or sets the ending character or characters to use when specifying database objects (for example, tables or columns) whose names contain characters such as spaces or reserved tokens.

SchemaSeparator

Ottiene o imposta il carattere da utilizzare come separatore tra l'identificatore di schema e altri identificatori.Gets or sets the character to be used for the separator between the schema identifier and any other identifiers.

(Ereditato da DbCommandBuilder)
SetAllValues

Specifica se in un'istruzione di aggiornamento sono inclusi tutti i valori delle colonne o soltanto quelli modificati.Specifies whether all column values in an update statement are included or only changed ones.

(Ereditato da DbCommandBuilder)
Site

Ottiene o imposta l'oggetto ISite dell'oggetto Component.Gets or sets the ISite of the Component.

(Ereditato da Component)

Metodi

ApplyParameterInfo(DbParameter, DataRow, StatementType, Boolean)

Attiva l'implementazione del provider per la classe DbCommandBuilder per consentire la gestione di proprietà aggiuntive dei parametri.Allows the provider implementation of the DbCommandBuilder class to handle additional parameter properties.

(Ereditato da DbCommandBuilder)
CreateObjRef(Type)

Consente di creare un oggetto che contiene tutte le informazioni rilevanti necessarie per la generazione del proxy utilizzato per effettuare la comunicazione con un oggetto remoto.Creates an object that contains all the relevant information required to generate a proxy used to communicate with a remote object.

(Ereditato da MarshalByRefObject)
DeriveParameters(OleDbCommand)

Recupera le informazioni sui parametri dalla stored procedure specificata nella classe OleDbCommand e compila l'insieme Parameters dell'oggetto OleDbCommand specificato.Retrieves parameter information from the stored procedure specified in the OleDbCommand and populates the Parameters collection of the specified OleDbCommand object.

Dispose()

Rilascia tutte le risorse usate da Component.Releases all resources used by the Component.

(Ereditato da Component)
Dispose(Boolean)

Rilascia le risorse non gestite usate da Component e facoltativamente rilascia le risorse gestite.Releases the unmanaged resources used by the Component and optionally releases the managed resources.

(Ereditato da Component)
Equals(Object)

Determina se l'oggetto specificato è uguale all'oggetto corrente.Determines whether the specified object is equal to the current object.

(Ereditato da Object)
GetDeleteCommand()

Ottiene l'oggetto OleDbCommand generato automaticamente, richiesto per eseguire le operazioni di eliminazione nell'origine dati.Gets the automatically generated OleDbCommand object required to perform deletions at the data source.

GetDeleteCommand(Boolean)

Ottiene l'oggetto OleDbCommand generato automaticamente, richiesto per eseguire le operazioni di eliminazione nell'origine dati.Gets the automatically generated OleDbCommand object required to perform deletions at the data source.

GetHashCode()

Funge da funzione hash predefinita.Serves as the default hash function.

(Ereditato da Object)
GetInsertCommand()

Ottiene l'oggetto OleDbCommand generato automaticamente, richiesto per eseguire le operazioni di inserimento nell'origine dati.Gets the automatically generated OleDbCommand object required to perform insertions at the data source.

GetInsertCommand(Boolean)

Ottiene l'oggetto OleDbCommand generato automaticamente, richiesto per eseguire le operazioni di inserimento nell'origine dati.Gets the automatically generated OleDbCommand object required to perform insertions at the data source.

GetLifetimeService()

Consente di recuperare l'oggetto servizio di durata corrente per controllare i criteri di durata per l'istanza.Retrieves the current lifetime service object that controls the lifetime policy for this instance.

(Ereditato da MarshalByRefObject)
GetParameterName(Int32)

Restituisce il nome del parametro specificato nel formato @p#.Returns the name of the specified parameter in the format of @p#. Da utilizzare quando si compila un generatore di comandi personalizzato.Use when building a custom command builder.

(Ereditato da DbCommandBuilder)
GetParameterName(String)

Restituisce il nome completo del parametro, dato il suo nome parziale.Returns the full parameter name, given the partial parameter name.

(Ereditato da DbCommandBuilder)
GetParameterPlaceholder(Int32)

Restituisce il segnaposto del parametro nell'istruzione SQL associata.Returns the placeholder for the parameter in the associated SQL statement.

(Ereditato da DbCommandBuilder)
GetSchemaTable(DbCommand)

Restituisce la tabella dello schema della classe DbCommandBuilder.Returns the schema table for the DbCommandBuilder.

(Ereditato da DbCommandBuilder)
GetService(Type)

Consente di restituire un oggetto che rappresenta un servizio fornito da Component o dal relativo Container.Returns an object that represents a service provided by the Component or by its Container.

(Ereditato da Component)
GetType()

Ottiene l'oggetto Type dell'istanza corrente.Gets the Type of the current instance.

(Ereditato da Object)
GetUpdateCommand()

Ottiene l'oggetto OleDbCommand generato automaticamente richiesto per eseguire le operazioni di aggiornamento nell'origine dati.Gets the automatically generated OleDbCommand object required to perform updates at the data source.

GetUpdateCommand(Boolean)

Ottiene l'oggetto OleDbCommand generato automaticamente, richiesto per eseguire le operazioni di aggiornamento nell'origine dati, eventualmente utilizzando le colonne per i nomi dei parametri.Gets the automatically generated OleDbCommand object required to perform updates at the data source, optionally using columns for parameter names.

InitializeCommand(DbCommand)

Reimposta le proprietà CommandTimeout, Transaction, CommandType e UpdateRowSource sul valore DbCommand.Resets the CommandTimeout, Transaction, CommandType, and UpdateRowSource properties on the DbCommand.

(Ereditato da DbCommandBuilder)
InitializeLifetimeService()

Ottiene un oggetto servizio di durata per controllare i criteri di durata per questa istanza.Obtains a lifetime service object to control the lifetime policy for this instance.

(Ereditato da MarshalByRefObject)
MemberwiseClone()

Crea una copia superficiale dell'oggetto Object corrente.Creates a shallow copy of the current Object.

(Ereditato da Object)
MemberwiseClone(Boolean)

Crea una copia dei riferimenti dell'oggetto MarshalByRefObject corrente.Creates a shallow copy of the current MarshalByRefObject object.

(Ereditato da MarshalByRefObject)
QuoteIdentifier(String)

Un identificatore senza virgolette con la lettera maiuscola o minuscola corretta per il catalogo, restituisce il form con virgolette corretto dell'identificatore.Given an unquoted identifier in the correct catalog case, returns the correct quoted form of that identifier. Ciò implica il sottoporre a escape in modo corretto eventuali virgolette nell'identificatore.This includes correctly escaping any embedded quotes in the identifier.

QuoteIdentifier(String, OleDbConnection)

Un identificatore senza virgolette con la lettera maiuscola o minuscola corretta per il catalogo, restituisce il form con virgolette corretto dell'identificatore.Given an unquoted identifier in the correct catalog case, returns the correct quoted form of that identifier. Ciò implica il sottoporre a escape in modo corretto eventuali virgolette nell'identificatore.This includes correctly escaping any embedded quotes in the identifier.

RefreshSchema()

Elimina i comandi associati all'oggetto OleDbCommandBuilder.Clears the commands associated with this OleDbCommandBuilder.

RowUpdatingHandler(RowUpdatingEventArgs)

Aggiunge un gestore eventi per l'evento RowUpdating.Adds an event handler for the RowUpdating event.

(Ereditato da DbCommandBuilder)
SetRowUpdatingHandler(DbDataAdapter)

Registra l'oggetto DbCommandBuilder per gestire l'evento RowUpdating per un oggetto DbDataAdapter.Registers the DbCommandBuilder to handle the RowUpdating event for a DbDataAdapter.

(Ereditato da DbCommandBuilder)
ToString()

Restituisce un oggetto String che contiene il nome dell'eventuale oggetto Component.Returns a String containing the name of the Component, if any. Questo metodo non deve essere sottoposto a override.This method should not be overridden.

(Ereditato da Component)
UnquoteIdentifier(String)

Un identificatore con virgolette, restituisce il form senza virgolette corretto relativo all'identificatore.Given a quoted identifier, returns the correct unquoted form of that identifier. Ciò implica il non sottoporre a escape in modo corretto eventuali virgolette nell'identificatore.This includes correctly un-escaping any embedded quotes in the identifier.

UnquoteIdentifier(String, OleDbConnection)

Un identificatore con virgolette, restituisce il form senza virgolette corretto relativo all'identificatore.Given a quoted identifier, returns the correct unquoted form of that identifier. Ciò implica il non sottoporre a escape in modo corretto eventuali virgolette nell'identificatore.This includes correctly un-escaping any embedded quotes in the identifier.

Eventi

Disposed

Si verifica quando il componente viene eliminato da una chiamata al metodo Dispose().Occurs when the component is disposed by a call to the Dispose() method.

(Ereditato da Component)

Si applica a

Vedi anche