यदि आप अपने कोड में TRANSACTIONS का उपयोग करते हैं, तो TRUNCATE को वापस लाया जा सकता है। यदि कोई लेन-देन नहीं है और TRUNCATE ऑपरेशन प्रतिबद्ध है, तो इसे लॉग फ़ाइल से पुनर्प्राप्त नहीं किया जा सकता है। TRUNCATE DDL ऑपरेशन है और यह लॉग फ़ाइल में लॉग इन नहीं है।
DELETE और TRUNCATE दोनों को TRANSACTION से घिरे होने पर वापस रोल किया जा सकता है यदि वर्तमान सत्र बंद नहीं है। यदि TRUNCATE को TRANSACTION से घिरे क्वेरी संपादक में लिखा गया है और यदि सत्र बंद है, तो इसे वापस नहीं किया जा सकता है लेकिन DELETE को वापस रोल किया जा सकता है।
USE tempdb
GO
-- Create Test Table
CREATE TABLE TruncateTest (ID INT)
INSERT INTO TruncateTest (ID)
SELECT 1
UNION ALL
SELECT 2
UNION ALL
SELECT 3
GO
-- Check the data before truncate
SELECT * FROM TruncateTest
GO
-- Begin Transaction
BEGIN TRAN
-- Truncate Table
TRUNCATE TABLE TruncateTest
GO
-- Check the data after truncate
SELECT * FROM TruncateTest
GO
-- Rollback Transaction
ROLLBACK TRAN
GO
-- Check the data after Rollback
SELECT * FROM TruncateTest
GO
-- Clean up
DROP TABLE TruncateTest
GO