OdbcCommandBuilder Klasa

Definicja

Automatycznie generuje polecenia pojedynczej tabeli, które są używane do uzgadniania zmian wprowadzonych w DataSet programie ze skojarzonym źródłem danych.Automatically generates single-table commands that are used to reconcile changes made to a DataSet with the associated data source. Klasa ta nie może być dziedziczona.This class cannot be inherited.

public ref class OdbcCommandBuilder sealed : System::Data::Common::DbCommandBuilder
public ref class OdbcCommandBuilder sealed : System::ComponentModel::Component
public sealed class OdbcCommandBuilder : System.Data.Common.DbCommandBuilder
public sealed class OdbcCommandBuilder : System.ComponentModel.Component
type OdbcCommandBuilder = class
    inherit DbCommandBuilder
type OdbcCommandBuilder = class
    inherit Component
Public NotInheritable Class OdbcCommandBuilder
Inherits DbCommandBuilder
Public NotInheritable Class OdbcCommandBuilder
Inherits Component
Dziedziczenie
Dziedziczenie
OdbcCommandBuilder

Przykłady

Poniższy przykład używa OdbcCommand , razem z OdbcDataAdapter i OdbcConnection , do wybierania wierszy ze źródła danych.The following example uses OdbcCommand, together with OdbcDataAdapter and OdbcConnection, to select rows from a data source. W przykładzie przeszedł zainicjowany DataSet , ciąg połączenia, ciąg zapytania, który jest instrukcją SELECT języka SQL, oraz ciąg, który jest nazwą tabeli źródła danych.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. Przykład tworzy 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

Uwagi

OdbcDataAdapterProgram nie generuje automatycznie instrukcji SQL wymaganych do uzgodnienia zmian wprowadzonych w DataSet skojarzonym ze źródłem danych.The OdbcDataAdapter does not automatically generate the SQL statements required to reconcile changes made to a DataSet associated with the data source. Można jednak utworzyć OdbcCommandBuilder obiekt generujący instrukcje SQL dla aktualizacji z jedną tabelą przez ustawienie SelectCommand właściwości OdbcDataAdapter .However, you can create an OdbcCommandBuilder object that generates SQL statements for single-table updates by setting the SelectCommand property of the OdbcDataAdapter. OdbcCommandBuilderNastępnie generuje wszelkie dodatkowe instrukcje SQL, które nie są ustawione.The OdbcCommandBuilder then generates any additional SQL statements that you do not set.

Relacja między OdbcDataAdapter i odpowiadająca jej OdbcCommandBuilder jest zawsze jeden-do-jednego.The relationship between an OdbcDataAdapter and its corresponding OdbcCommandBuilder is always one-to-one. Aby utworzyć tę zgodność, należy ustawić OdbcDataAdapter Właściwość OdbcCommandBuilder obiektu.To create this correspondence, you set the OdbcDataAdapter property of the OdbcCommandBuilder object. Powoduje to OdbcCommandBuilder zarejestrowanie się jako odbiornika, który tworzy dane wyjściowe RowUpdating zdarzeń, które mają wpływ na DataSet .This causes the OdbcCommandBuilder to register itself as a listener, which produces the output of RowUpdating events that affect the DataSet.

Aby wygenerować instrukcje INSERT, UPDATE lub DELETE, program OdbcCommandBuilder używa SelectCommand właściwości do pobrania wymaganego zestawu metadanych.To generate INSERT, UPDATE, or DELETE statements, the OdbcCommandBuilder uses the SelectCommand property to retrieve a required set of metadata. Jeśli zmienisz wartość SelectCommand po pobraniu metadanych, na przykład po pierwszej aktualizacji, należy wywołać RefreshSchema metodę w celu zaktualizowania metadanych.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.

Uwaga

Jeśli instrukcja SELECT przypisana do SelectCommand właściwości używa aliasów nazw kolumn, wyniki instrukcji INSERT, Update i DELETE mogą być niedokładne lub niepowodzenie.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. Jeśli źródłowy sterownik ODBC nie może zapewnić odpowiedniej podstawowej nazwy kolumny dla nazwy kolumny aliasu (przy użyciu wartości SQL_DESC_BASE_COLUMN_NAME SQLColAttribute ), nazwy aliasu można użyć w wygenerowanych instrukcjach INSERT, Update i 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. Na przykład sterownik Microsoft ODBC dla programu Oracle zwraca nazwę aliasu jako nazwę kolumny bazowej.For example, the Microsoft ODBC Driver for Oracle returns the alias name as the base column name. W związku z tym wygenerowane instrukcje INSERT, UPDATE i DELETE spowodują błędy.Therefore, the generated INSERT, UPDATE, and DELETE statements would cause errors.

OdbcCommandBuilderUżywa również Connection CommandTimeout właściwości, i, Transaction do których odwołuje się SelectCommand .The OdbcCommandBuilder also uses the Connection, CommandTimeout, and Transaction properties referenced by the SelectCommand. Użytkownik powinien wywołać RefreshSchema , jeśli co najmniej jedna z tych właściwości zostanie zmodyfikowana lub jeśli wartość SelectCommand samej właściwości zostanie zmieniona.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. W przeciwnym InsertCommand razie UpdateCommand właściwości, i DeleteCommand zachowują poprzednie wartości.Otherwise the InsertCommand, UpdateCommand, and DeleteCommand properties retain their previous values.

W przypadku wywołania Dispose , OdbcCommandBuilder zostaje on odkojarzony od OdbcDataAdapter i wygenerowane polecenia nie będą już używane.If you call Dispose, the OdbcCommandBuilder is disassociated from the OdbcDataAdapter, and the generated commands are no longer used.

Konstruktory

OdbcCommandBuilder()

Inicjuje nowe wystąpienie klasy OdbcCommandBuilder.Initializes a new instance of the OdbcCommandBuilder class.

OdbcCommandBuilder(OdbcDataAdapter)

Inicjuje nowe wystąpienie OdbcCommandBuilder klasy za pomocą skojarzonego OdbcDataAdapter obiektu.Initializes a new instance of the OdbcCommandBuilder class with the associated OdbcDataAdapter object.

Właściwości

CanRaiseEvents

Pobiera wartość wskazującą, czy składnik może zgłosić zdarzenie.Gets a value indicating whether the component can raise an event.

(Odziedziczone po Component)
CatalogLocation

Pobiera lub ustawia CatalogLocation dla wystąpienia DbCommandBuilder klasy.Gets or sets the CatalogLocation for an instance of the DbCommandBuilder class.

(Odziedziczone po DbCommandBuilder)
CatalogSeparator

Pobiera lub ustawia ciąg używany jako separator wykazu dla wystąpienia DbCommandBuilder klasy.Gets or sets a string used as the catalog separator for an instance of the DbCommandBuilder class.

(Odziedziczone po DbCommandBuilder)
ConflictOption

Określa, który ConflictOption ma być używany przez DbCommandBuilder .Specifies which ConflictOption is to be used by the DbCommandBuilder.

(Odziedziczone po DbCommandBuilder)
Container

Pobiera IContainer , który zawiera Component .Gets the IContainer that contains the Component.

(Odziedziczone po Component)
DataAdapter

Pobiera lub ustawia OdbcDataAdapter obiekt, dla którego ten OdbcCommandBuilder obiekt będzie GENEROWAŁ instrukcje SQL.Gets or sets an OdbcDataAdapter object for which this OdbcCommandBuilder object will generate SQL statements.

DesignMode

Pobiera wartość wskazującą, czy Component jest aktualnie w trybie projektowania.Gets a value that indicates whether the Component is currently in design mode.

(Odziedziczone po Component)
Events

Pobiera listę programów obsługi zdarzeń, które są dołączone do tego elementu Component .Gets the list of event handlers that are attached to this Component.

(Odziedziczone po Component)
QuotePrefix

Pobiera lub ustawia początkowy znak lub znaki, które mają być używane podczas pracy z obiektami bazy danych (na przykład tabele lub kolumny), których nazwy zawierają znaki takie jak spacje lub tokeny zarezerwowane.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.

QuotePrefix

Pobiera lub ustawia początkowy znak lub znaki, które mają być używane podczas określania obiektów bazy danych (na przykład tabel lub kolumn), których nazwy zawierają znaki takie jak spacje lub tokeny zarezerwowane.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.

(Odziedziczone po DbCommandBuilder)
QuoteSuffix

Pobiera lub ustawia znak końcowy lub znaki, które mają być używane podczas pracy z obiektami bazy danych (na przykład tabele lub kolumny), których nazwy zawierają znaki takie jak spacje lub tokeny zarezerwowane.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.

QuoteSuffix

Pobiera lub ustawia znak końcowy lub znaki, które mają być używane podczas określania obiektów bazy danych (na przykład tabel lub kolumn), których nazwy zawierają znaki takie jak spacje lub tokeny zarezerwowane.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.

(Odziedziczone po DbCommandBuilder)
SchemaSeparator

Pobiera lub ustawia znak, który ma być używany dla separatora między identyfikatorem schematu i innymi identyfikatorami.Gets or sets the character to be used for the separator between the schema identifier and any other identifiers.

(Odziedziczone po DbCommandBuilder)
SetAllValues

Określa, czy wszystkie wartości kolumn w instrukcji Update są uwzględniane lub zmieniane.Specifies whether all column values in an update statement are included or only changed ones.

(Odziedziczone po DbCommandBuilder)
Site

Pobiera lub ustawia wartość ISite Component .Gets or sets the ISite of the Component.

(Odziedziczone po Component)

Metody

ApplyParameterInfo(DbParameter, DataRow, StatementType, Boolean)

Zezwala implementacji dostawcy DbCommandBuilder klasy na obsługę dodatkowych właściwości parametrów.Allows the provider implementation of the DbCommandBuilder class to handle additional parameter properties.

(Odziedziczone po DbCommandBuilder)
CreateObjRef(Type)

Tworzy obiekt, który zawiera wszystkie istotne informacje wymagane do wygenerowania serwera proxy używanego do komunikacji z obiektem zdalnym.Creates an object that contains all the relevant information required to generate a proxy used to communicate with a remote object.

(Odziedziczone po MarshalByRefObject)
DeriveParameters(OdbcCommand)

Pobiera informacje o parametrach z procedury składowanej określonej w parametrze OdbcCommand i wypełnia Parameters kolekcję określonego OdbcCommand obiektu.Retrieves parameter information from the stored procedure specified in the OdbcCommand and populates the Parameters collection of the specified OdbcCommand object.

Dispose()

Zwalnia wszelkie zasoby używane przez element Component.Releases all resources used by the Component.

(Odziedziczone po Component)
Dispose(Boolean)

Zwalnia zasoby niezarządzane używane przez element DbCommandBuilder i opcjonalnie zwalnia zasoby zarządzane.Releases the unmanaged resources used by the DbCommandBuilder and optionally releases the managed resources.

(Odziedziczone po DbCommandBuilder)
Dispose(Boolean)

Zwalnia zasoby niezarządzane używane przez element Component i opcjonalnie zwalnia zasoby zarządzane.Releases the unmanaged resources used by the Component and optionally releases the managed resources.

(Odziedziczone po Component)
Equals(Object)

Określa, czy dany obiekt jest taki sam, jak bieżący obiekt.Determines whether the specified object is equal to the current object.

(Odziedziczone po Object)
GetDeleteCommand()

Pobiera automatycznie wygenerowany OdbcCommand obiekt wymagany do wykonania operacji usuwania w źródle danych.Gets the automatically generated OdbcCommand object required to perform deletions at the data source.

GetDeleteCommand(Boolean)

Pobiera automatycznie wygenerowany OdbcCommand obiekt wymagany do wykonania operacji usuwania w źródle danych.Gets the automatically generated OdbcCommand object required to perform deletions at the data source.

GetHashCode()

Służy jako domyślna funkcja skrótu.Serves as the default hash function.

(Odziedziczone po Object)
GetInsertCommand()

Pobiera automatycznie wygenerowany OdbcCommand obiekt wymagany do wykonania operacji wstawienia w źródle danych.Gets the automatically generated OdbcCommand object required to perform insertions at the data source.

GetInsertCommand(Boolean)

Pobiera automatycznie wygenerowany OdbcCommand obiekt wymagany do wykonania operacji wstawienia w źródle danych.Gets the automatically generated OdbcCommand object required to perform insertions at the data source.

GetLifetimeService()

Pobiera bieżący obiekt usługi okresu istnienia, który kontroluje zasady okresu istnienia dla tego wystąpienia.Retrieves the current lifetime service object that controls the lifetime policy for this instance.

(Odziedziczone po MarshalByRefObject)
GetParameterName(Int32)

Zwraca nazwę określonego parametru w formacie @p #.Returns the name of the specified parameter in the format of @p#. Używany podczas kompilowania niestandardowego konstruktora poleceń.Use when building a custom command builder.

(Odziedziczone po DbCommandBuilder)
GetParameterName(String)

Zwraca pełną nazwę parametru, uwzględniając nazwę parametru częściowego.Returns the full parameter name, given the partial parameter name.

(Odziedziczone po DbCommandBuilder)
GetParameterPlaceholder(Int32)

Zwraca symbol zastępczy dla parametru w skojarzonej instrukcji SQL.Returns the placeholder for the parameter in the associated SQL statement.

(Odziedziczone po DbCommandBuilder)
GetSchemaTable(DbCommand)

Zwraca tabelę schematów dla DbCommandBuilder .Returns the schema table for the DbCommandBuilder.

(Odziedziczone po DbCommandBuilder)
GetService(Type)

Zwraca obiekt, który reprezentuje usługę dostarczoną przez Component lub przez Container .Returns an object that represents a service provided by the Component or by its Container.

(Odziedziczone po Component)
GetType()

Pobiera Type bieżące wystąpienie.Gets the Type of the current instance.

(Odziedziczone po Object)
GetUpdateCommand()

Pobiera automatycznie wygenerowany OdbcCommand obiekt wymagany do przeprowadzenia aktualizacji w źródle danych.Gets the automatically generated OdbcCommand object required to perform updates at the data source.

GetUpdateCommand(Boolean)

Pobiera automatycznie wygenerowany OdbcCommand obiekt wymagany do przeprowadzenia aktualizacji w źródle danych.Gets the automatically generated OdbcCommand object required to perform updates at the data source.

InitializeCommand(DbCommand)

Resetuje CommandTimeout właściwości, Transaction , CommandType i UpdateRowSource w DbCommand .Resets the CommandTimeout, Transaction, CommandType, and UpdateRowSource properties on the DbCommand.

(Odziedziczone po DbCommandBuilder)
InitializeLifetimeService()

Uzyskuje obiekt usługi istnienia w celu kontrolowania zasad okresu istnienia dla tego wystąpienia.Obtains a lifetime service object to control the lifetime policy for this instance.

(Odziedziczone po MarshalByRefObject)
MemberwiseClone()

Tworzy skróconą kopię bieżącego elementu Object .Creates a shallow copy of the current Object.

(Odziedziczone po Object)
MemberwiseClone(Boolean)

Tworzy skróconą kopię bieżącego MarshalByRefObject obiektu.Creates a shallow copy of the current MarshalByRefObject object.

(Odziedziczone po MarshalByRefObject)
QuoteIdentifier(String)

Jeśli w poprawnym przypadku wykazu Wystąpił nieokreślony identyfikator, funkcja zwraca poprawną, cytowaną formę tego identyfikatora.Given an unquoted identifier in the correct catalog case, returns the correct quoted form of that identifier. Obejmuje to poprawne anulowanie wszystkich osadzonych cudzysłowów w identyfikatorze.This includes correctly escaping any embedded quotes in the identifier.

QuoteIdentifier(String, OdbcConnection)

Jeśli w poprawnym przypadku wykazu Wystąpił nieokreślony identyfikator, funkcja zwraca poprawną, cytowaną formę tego identyfikatora.Given an unquoted identifier in the correct catalog case, returns the correct quoted form of that identifier. Obejmuje to poprawne anulowanie wszystkich osadzonych cudzysłowów w identyfikatorze.This includes correctly escaping any embedded quotes in the identifier.

RefreshSchema()

Czyści polecenia skojarzone z tym elementem OdbcCommandBuilder .Clears the commands associated with this OdbcCommandBuilder.

RefreshSchema()

Czyści polecenia skojarzone z tym elementem DbCommandBuilder .Clears the commands associated with this DbCommandBuilder.

(Odziedziczone po DbCommandBuilder)
RowUpdatingHandler(RowUpdatingEventArgs)

Dodaje procedurę obsługi zdarzeń dla RowUpdating zdarzenia.Adds an event handler for the RowUpdating event.

(Odziedziczone po DbCommandBuilder)
SetRowUpdatingHandler(DbDataAdapter)

Rejestruje, DbCommandBuilder Aby obsłużyć RowUpdating zdarzenie dla elementu DbDataAdapter .Registers the DbCommandBuilder to handle the RowUpdating event for a DbDataAdapter.

(Odziedziczone po DbCommandBuilder)
ToString()

Zwraca wartość String zawierającą nazwę Component (jeśli istnieje).Returns a String containing the name of the Component, if any. Ta metoda nie powinna być przesłaniana.This method should not be overridden.

(Odziedziczone po Component)
UnquoteIdentifier(String)

Podając identyfikator w cudzysłowie, zwraca poprawną niecytowaną formę tego identyfikatora, w tym poprawne anulowanie wszystkich osadzonych cudzysłowów w identyfikatorze.Given a quoted identifier, returns the correct unquoted form of that identifier, including correctly unescaping any embedded quotes in the identifier.

UnquoteIdentifier(String, OdbcConnection)

Podając identyfikator w cudzysłowie, zwraca poprawną niecytowaną formę tego identyfikatora, w tym poprawne anulowanie wszystkich osadzonych cudzysłowów w identyfikatorze.Given a quoted identifier, returns the correct unquoted form of that identifier, including correctly unescaping any embedded quotes in the identifier.

Zdarzenia

Disposed

Występuje, gdy składnik zostanie usunięty przez wywołanie Dispose() metody.Occurs when the component is disposed by a call to the Dispose() method.

(Odziedziczone po Component)

Dotyczy

Zobacz też