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

前端之家收集整理的这篇文章主要介绍了我可以先在一个t-SQL事务中选择SELECT然后删除记录吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我无法弄清楚这是否是可接受的操作.我需要从sql Server 2008数据库中选择记录,然后删除它们,所有这些都是ASP.NET代码中的单个事务.请注意,.NET代码必须能够检索首先选择的数据.

这样的东西:

  1. SELECT * FROM [tbl] WHERE [id] > 6;
  2. DELETE FROM [tbl] WHERE [id] > 6

我是trying itsql小提琴,但如果我这样做:

  1. SELECT * FROM [tbl]

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

编辑按照下面的要求,这里是检索记录的完整.NET代码

  1. string strsqlStatement = "SELECT * FROM [tbl] WHERE [id] > 6;" +
  2. "DELETE FROM [tbl] WHERE [id] > 6";
  3.  
  4. using (sqlCommand cmd = new sqlCommand(strsqlStatement,connectionString))
  5. {
  6. using (sqlDataReader rdr = cmd.ExecuteReader())
  7. {
  8. while(rdr.Read())
  9. {
  10. //Read values
  11. val0 = rdr.GetInt32(0);
  12. val3 = rdr.GetInt32(3);
  13. //etc.
  14. }
  15. }
  16. }

解决方法

这将执行选择和删除simultanIoUs:
  1. delete from [tbl] output deleted.* WHERE [id] > 6

猜你在找的MsSQL相关文章