Успях да изпълня код, който винаги работи и не генерира грешки, когато таблицата не съществува:
SELECT Count(*)
INTO @exists
FROM information_schema.tables
WHERE table_schema = [DATABASE_NAME]
AND table_type = 'BASE TABLE'
AND table_name = 'video_top_day';
SET @query = If(@exists>0,
'RENAME TABLE video_top_day TO video_top_day_for_delete',
'SELECT \'nothing to rename\' status');
PREPARE stmt FROM @query;
EXECUTE stmt;
Когато не искате да замените [DATABASE NAME]
ръчно можете да използвате следната променлива
SELECT DATABASE() INTO @db_name FROM DUAL;