我可以先在一个t-SQL事务中选择SELECT然后删除记录吗?

c00*_*0fd 9 sql t-sql sql-server-2008

我无法弄清楚这是否是可接受的操作.我需要从SQL Server 2008数据库中选择记录然后删除它们,所有这些都是ASP.NET代码中的单个事务.请注意,.NET代码必须能够检索首先选择的数据.

这样的东西:

SELECT * FROM [tbl] WHERE [id] > 6;
DELETE FROM [tbl] WHERE [id] > 6
Run Code Online (Sandbox Code Playgroud)

我正在尝试使用SQL Fiddle,但如果我这样做:

SELECT * FROM [tbl]
Run Code Online (Sandbox Code Playgroud)

我得到了完整的表格,好像没有删除任何内容.

编辑按照下面的要求,这里是检索记录的完整.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.
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

t-c*_*.dk 24

这将执行选择和删除simultanious:

delete from [tbl] output deleted.* WHERE [id] > 6
Run Code Online (Sandbox Code Playgroud)