如何将mysql数据库备份作为csv文件,并在此之后定期截断表。我怎样才能使用mysql实现这一点。
任何类型的帮助都将受到赞赏。
答案 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