Nie mogę stwierdzić, czy jest to operacja akceptowalna. Muszę wybrać rekordy z bazy danych SQL Server 2008, a następnie je usunąć, wszystkie jako pojedynczą transakcję z kodu ASP.NET. Zauważ, że kod .NET musi być w stanie pobrać dane, które zostały wybrane jako pierwsze.Czy mogę najpierw WYBRAĆ, a następnie USUWAĆ rekordy w jednej transakcji t-SQL?
Coś takiego jak:
SELECT * FROM [tbl] WHERE [id] > 6;
DELETE FROM [tbl] WHERE [id] > 6
jestem trying it z SQL Fiddle ale jeśli robię:
SELECT * FROM [tbl]
uzyskać pełną tabelę tak, jakby nic nie zostało usunięte.
EDIT Zgodnie z wnioskiem poniżej oto pełny kod .NET aby pobrać rekordy:
string strSQLStatement = "SELECT * FROM [tbl] WHERE [id] > 6;" +
"DELETE FROM [tbl] WHERE [id] > 6";
using (SqlCommand cmd = new SqlCommand(strSQLStatement, connectionString))
{
using (SqlDataReader rdr = cmd.ExecuteReader())
{
while(rdr.Read())
{
//Read values
val0 = rdr.GetInt32(0);
val3 = rdr.GetInt32(3);
//etc.
}
}
}
Tak można. Pokaż nam kod, którego używasz. –
@PreetSangha: Masz na myśli kod .NET? Lub SQL? Jeśli masz na myśli to ostatnie, to jest tak, jak pokazałem powyżej. – c00000fd
kod .Net jest ważniejszy tutaj – TGH