如何在bash中捕获mysql错误

时间:2014-12-09 11:55:17

标签: mysql bash mysqldump

我有一个bash脚本,它从一个db导出一个表并将其导入另一个db。像魅力一样。

然而,因为我想让它作为一个cronjob运行,我希望它发送一封电子邮件,以防万一我出错了。但是我怎么知道我是否有像例如:

这样的错误
ERROR 1045 (28000): Access denied for user 'importuser'@'192.168.xxx.xxx' (using password: YES)

任何想法怎么做?这是关键段落:

mysql --user=$rep_user --password=$rep_password --host=$rep_host --database=$rep_name < /tmp/${i}.sql

我已经尝试了

    result=`mysql --user=$rep_user --password=$rep_password --host=$rep_host --database=$rep_name < /tmp/${i}.sql`
    echo $result >> $EMAILMESSAGE

但它并没有出现在我的$ EMAILMESSAGE

有人知道如何实现这个目标吗?

2 个答案:

答案 0 :(得分:5)

我假设你的$EMAILMESSAGE变量已经初始化并保存文件的位置。如果是这样,您应该能够按如下方式获得结果(仅当命令失败时):

result=$(mysql --user=$rep_user --password=$rep_password --host=$rep_host --database=$rep_name < /tmp/${i}.sql 2>&1 )
[ $? = 0 ] || echo $result >> $EMAILMESSAGE

答案 1 :(得分:3)

mysql与任何其他unix命令行工具一样,您可以使用该命令的退出状态。

因此,您可以在if中使用它,使用短路||&&,或直接检查$?