gpt4 book ai didi

mysql - 如何在 bash 中捕获 mysql 错误

转载 作者:可可西里 更新时间:2023-11-01 07:49:38 24 4
gpt4 key购买 nike

我有一个 bash 脚本,它从一个数据库中导出一个表并将其导入到另一个数据库中。就像一个魅力。

但是,因为我想让它作为一个 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 中

有人知道如何实现这一点吗?

最佳答案

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

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

关于mysql - 如何在 bash 中捕获 mysql 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27378377/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com