SqlDataAdapter.UpdateCommand Vlastnost
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Získá nebo nastaví transact-SQL příkaz nebo uloženou proceduru sloužící k aktualizaci záznamů ve zdroji dat.
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
Hodnota vlastnosti
Slouží SqlCommand k Update(DataSet) aktualizaci záznamů v databázi, které odpovídají upraveným řádkům v objektu DataSet.
Příklady
Následující příklad vytvoří SqlDataAdapter a nastaví SelectCommandvlastnosti , InsertCommandUpdateCommand a DeleteCommand . Předpokládá, že jste již vytvořili SqlConnection objekt.
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;
}
}
Poznámky
Pokud Updatenení tato vlastnost nastavena a informace o primárním klíči jsou v objektu DataSet, UpdateCommand lze automaticky vygenerovat, pokud nastavíte SelectCommand vlastnost a použijete SqlCommandBuilder. Všechny další příkazy, které nenastavíte, pak vygeneruje SqlCommandBuilder. Tato logika generování vyžaduje, aby informace o klíčovém sloupci DataSetbyly v souboru . Další informace najdete v tématu Generování příkazů pomocí CommandBuilders.
Pokud UpdateCommand je přiřazen k dříve vytvořenému SqlCommandobjektu SqlCommand , není klonován. Objekt UpdateCommand udržuje odkaz na dříve vytvořený SqlCommand objekt.
Poznámka
Pokud spuštění tohoto příkazu vrátí řádky, aktualizované řádky mohou být sloučeny s DataSet v závislosti na tom, jak nastavíte Vlastnost UpdatedRowSource objektu SqlCommand .
Pro každý sloupec, který rozšíříte do zdroje dat v Updatesystému , je potřeba přidat parametr do InsertCommand
, UpdateCommand
nebo DeleteCommand
.
Vlastnost SourceColumn
parametru by měla být nastavena na název sloupce. To znamená, že hodnota parametru není nastavena ručně, ale převzata z konkrétního sloupce v aktuálně zpracovaném řádku.