我可以先在一个t-SQL事务中选择SELECT然后删除记录吗?
发布时间:2020-12-12 06:45:07 所属栏目:MsSql教程 来源:网络整理
导读:我无法弄清楚这是否是可接受的操作.我需要从SQL Server 2008数据库中选择记录,然后删除它们,所有这些都是ASP.NET代码中的单个事务.请注意,.NET代码必须能够检索首先选择的数据. 这样的东西: SELECT * FROM [tbl] WHERE [id] 6;DELETE FROM [tbl] WHERE [id]
我无法弄清楚这是否是可接受的操作.我需要从SQL Server 2008数据库中选择记录,然后删除它们,所有这些都是ASP.NET代码中的单个事务.请注意,.NET代码必须能够检索首先选择的数据.
这样的东西: SELECT * FROM [tbl] WHERE [id] > 6; DELETE FROM [tbl] WHERE [id] > 6 我是trying it与SQL小提琴,但如果我这样做: 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. } } } 解决方法这将执行选择和删除simultanious:delete from [tbl] output deleted.* WHERE [id] > 6 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |