我不知道这是否是可接受的操作。我需要从 SQL Server 2008 数据库中选择记录,然后删除它们,所有这些都作为 ASP.NET 代码中的单个事务。请注意,.NET 代码必须能够检索第一次选择的数据。
像这样的东西:
SELECT * FROM [tbl] WHERE [id] > 6;
DELETE FROM [tbl] WHERE [id] > 6
我正在使用 SQL Fiddle尝试它,但如果我这样做:
SELECT * FROM [tbl]
我得到了完整的表,好像没有任何内容被删除。
编辑按照下面的要求,这里是检索记录的完整 .NET 代码:
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.
}
}
}