粗糙的传球在重写 -
#!/bin/bash
domainName=$1
status=$2
echo "Verifying domain"
case status in
$status) ping -c 1 $domainName || {
echo "Cannot ping $domainName" >&2
exit 1
} ;;
*) echo "Invalid argument '$status'" >&2
exit 1 ;;
esac
sql="SELECT * FROM DomainSSL WHERE domainName='$domainName'"
mssql -f csv -c ~/applications/mssql/mssql.json -q "$sql" # mark here
rc=$?
if ((rc)) # nonzero
then echo "FAIL: rc $rc on [$sql]" >&2
else echo "SUCCESS: $sql"
fi
您也可能想尝试保存输出和错误供以后分析。 从上方# mark
重写,
mssql -f csv -c ~/applications/mssql/mssql.json -q "$sql" >ok 2>oops
rc=$?
if ((rc)) # nonzero
then echo -e "FAIL: rc $rc on [$sql]:\n$(<oops)" >&2
case "$(grep SQLSTATE oops)" in
*ER_DUP_KEY*) : code to handle duplicate keys error ;;
# any other errors you choose to handle . . .
*) : code for bailing on errors you don't care to handle ;;
esac
else echo "SUCCESS: $sql"
fi
C.F. mysql文档here
这只是一个通用模板。希望能帮助到你。随意要求澄清。
让我们看看你的脚本结构的一个例子。 –
编辑帖子,以便格式化它。 ;!) –
#/斌/庆典 则domainName = $ 1 状态= $ 16 而[[$#-gt 0]];在 状态下执行 “$ 1”的情况) mssql -f csv -c〜/ applications/mssql/mssql.json -q“SELECT * FROM DomainSSL WHERE domainName ='$ 1'” ;; *) 回声 “无效参数:$ 1” 出口1个 ESAC 转变 做 回声 “SELECT * FROM域名型其中DomainName = '$ 1' '$ 2'” – jphil1971