首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >sql server中Delete和Truncate的区别。我说错了吗...?

sql server中Delete和Truncate的区别。我说错了吗...?
EN

Stack Overflow用户
提问于 2010-08-26 22:42:51
回答 3查看 3.1K关注 0票数 17

在最近的一次采访中,我被问及两者之间的区别。我回答将军说我们所知道的..。

然后,面试官问是否可以回滚截断?我回答不..。

面试官说可以回滚,让我先看一下delete和truncate的幕后操作细节,稍后再检查。

好吧,我在这里发布这个问题,不仅仅是为了定义和我们知道的事情……而是深入到它的核心。在这方面给予启发将是非常有用的。

提前感谢

EN

回答 3

Stack Overflow用户

发布于 2010-08-26 22:59:35

truncate操作将释放属于该表的所有页。这些释放会被记录下来,并且可以回滚。删除会将所有行标记为已删除,并记录每个单独的行。

票数 5
EN

Stack Overflow用户

发布于 2010-08-26 22:45:44

如果您在事务中立即执行Truncate,则可以回滚。它不能像在数据库恢复中那样稍后从事务日志中回滚。在事务中测试它,并查看。

票数 3
EN

Stack Overflow用户

发布于 2010-08-26 23:10:30

那么到最后,您可以将截断作为事务的一部分回滚,但不能在提交后回滚?

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3576229

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档