If you put the database in Simple Mode and run the following code;
SET ROWCOUNT 10000
WHILE 1=1
BEGIN
DELETE from sys.syslogdata
where msghostname = 'SERVER.it.Dev.com'
IF @@ROWCOUNT = 0 BREAK
END
you won´t get a logfile that grows to much. It will delete 10.000 rows (or as much as you descibes in 'rowcount').
After each time you do this it will put a checkpoint and can reuse the log again. If you change the delete part it can be used in many situations
If you want all data in a table to be deleted 'truncate table' is much faster!
!! At delete you won´t reset a counter, this will be done with a truncate. If you want to reset a counter you may want to look into 'CHECKIDENT'.
No comments:
Post a Comment