MySql备份和截断表

时间:2014-10-22 05:19:50

标签: mysql database-backups

如何将mysql数据库备份作为csv文件,并在此之后定期截断表。我怎样才能使用mysql实现这一点。

任何类型的帮助都将受到赞赏。

2 个答案:

答案 0 :(得分:0)

使用MySQL事件;确保MySQL以" - event-scheduler = ON"启动,或者添加" event-scheduler = ON"到你的my.cnf文件。

添加所需任务的代码如下所示;

DELIMITER $$

CREATE 
    EVENT `backup_and_truncate` 
    ON SCHEDULE EVERY 1 WEEK STARTS '2000-01-01 00:00:00' 
    DO BEGIN

        -- Export Data
    SELECT *
    FROM my_table
    INTO OUTFILE '/tmp/my_table.csv'
    FIELDS TERMINATED BY ','
    ENCLOSED BY '"'
    LINES TERMINATED BY '\n';

        -- Truncate Table
    TRUNCATE my_table;

    END */$$

DELIMITER ;

答案 1 :(得分:0)

最好将表备份到.sql文件中,而不是使用csv文件,这在导入数据库时​​会再次为您提供帮助。

如果您是Linux用户,则可以使用bash脚本和cron作业进行常规备份。

示例脚本:

#!/bin/bash
_user="root"
_password="YourMySQLRootPassword"

mysqldump -u${_user} -p${_password} DB_Name TableName > Table_name_`date +%Y%m%d`.sql  # here date command is executed for present date
mysql -u${_user} -p{_password} -e "truncate table DB_Name.TableName"

在截断表之前,可以检查转储命令是否成功,然后使用“ if”条件执行表截断。 要快速介绍,您可以查看此链接https://www.youtube.com/watch?v=hwrnmQumtPw