SqlDataAdapter.UpdateCommand Eigenschaft
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
Ruft eine Transact-SQL-Anweisung oder gespeicherte Prozedur ab, um Datensätze in der Datenquelle zu aktualisieren, oder legt diese fest.
public:
property Microsoft::Data::SqlClient::SqlCommand ^ UpdateCommand { Microsoft::Data::SqlClient::SqlCommand ^ get(); void set(Microsoft::Data::SqlClient::SqlCommand ^ value); };
public Microsoft.Data.SqlClient.SqlCommand UpdateCommand { get; set; }
member this.UpdateCommand : Microsoft.Data.SqlClient.SqlCommand with get, set
Public Property UpdateCommand As SqlCommand
Eigenschaftswert
Ein SqlCommand, mit dem während der Ausführung von Update(DataSet) in der Datenbank Datensätze aktualisiert werden, die geänderten Zeilen im DataSet entsprechen.
Beispiele
Im folgenden Beispiel wird ein SqlDataAdapter erstellt und die SelectCommandEigenschaften , InsertCommandund DeleteCommandUpdateCommand festgelegt. Es wird davon ausgegangen, dass Sie bereits ein SqlConnection Objekt erstellt haben.
using Microsoft.Data.SqlClient;
class Program
{
static void Main()
{
}
public static SqlDataAdapter CreateCustomerAdapter(
SqlConnection connection)
{
SqlDataAdapter adapter = new SqlDataAdapter();
// Create the SelectCommand.
SqlCommand command = new SqlCommand("SELECT * FROM Customers " +
"WHERE Country = @Country AND City = @City", connection);
// Add the parameters for the SelectCommand.
command.Parameters.Add("@Country", SqlDbType.NVarChar, 15);
command.Parameters.Add("@City", SqlDbType.NVarChar, 15);
adapter.SelectCommand = command;
// Create the InsertCommand.
command = new SqlCommand(
"INSERT INTO Customers (CustomerID, CompanyName) " +
"VALUES (@CustomerID, @CompanyName)", connection);
// Add the parameters for the InsertCommand.
command.Parameters.Add("@CustomerID", SqlDbType.NChar, 5, "CustomerID");
command.Parameters.Add("@CompanyName", SqlDbType.NVarChar, 40, "CompanyName");
adapter.InsertCommand = command;
// Create the UpdateCommand.
command = new SqlCommand(
"UPDATE Customers SET CustomerID = @CustomerID, CompanyName = @CompanyName " +
"WHERE CustomerID = @oldCustomerID", connection);
// Add the parameters for the UpdateCommand.
command.Parameters.Add("@CustomerID", SqlDbType.NChar, 5, "CustomerID");
command.Parameters.Add("@CompanyName", SqlDbType.NVarChar, 40, "CompanyName");
SqlParameter parameter = command.Parameters.Add(
"@oldCustomerID", SqlDbType.NChar, 5, "CustomerID");
parameter.SourceVersion = DataRowVersion.Original;
adapter.UpdateCommand = command;
// Create the DeleteCommand.
command = new SqlCommand(
"DELETE FROM Customers WHERE CustomerID = @CustomerID", connection);
// Add the parameters for the DeleteCommand.
parameter = command.Parameters.Add(
"@CustomerID", SqlDbType.NChar, 5, "CustomerID");
parameter.SourceVersion = DataRowVersion.Original;
adapter.DeleteCommand = command;
return adapter;
}
}
Hinweise
Wenn Updatediese Eigenschaft nicht festgelegt ist und Primärschlüsselinformationen in DataSetvorhanden sind, kann automatisch UpdateCommand generiert werden, wenn Sie die SelectCommand -Eigenschaft festlegen und verwenden SqlCommandBuilder. Anschließend werden alle zusätzlichen Befehle, die Sie nicht festlegen, vom SqlCommandBuildergeneriert. Diese Generierungslogik erfordert, dass wichtige Spalteninformationen im DataSetvorhanden sind. Weitere Informationen finden Sie unter Generieren von Befehlen mit CommandBuilder-Objekten.
Wenn UpdateCommand einem zuvor erstellten SqlCommandzugewiesen ist, wird der SqlCommand nicht geklont. Der UpdateCommand verwaltet einen Verweis auf das zuvor erstellte SqlCommand Objekt.
Hinweis
Wenn die Ausführung dieses Befehls Zeilen zurückgibt, können die aktualisierten Zeilen mit dem DataSet zusammengeführt werden, je nachdem, wie Sie die UpdatedRowSource-Eigenschaft des SqlCommand Objekts festlegen.
Für jede Spalte, die Sie an die Datenquelle für Updateweitergeben, sollte ein Parameter zu InsertCommand
, UpdateCommand
oder DeleteCommand
hinzugefügt werden.
Die SourceColumn
-Eigenschaft des Parameters sollte auf den Namen der Spalte festgelegt werden. Dies gibt an, dass der Wert des Parameters nicht manuell festgelegt wird, sondern aus der bestimmten Spalte in der aktuell verarbeiteten Zeile übernommen wird.