Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Problem mit Rückgabevariable in Bash

Ein einfacherer Weg ist :

var=$(mysql -h abcdcef.com --port=3306 --user=root --password=hbbfe --batch --skip-column-names -Dshop -e "select count(*) from shop_tab where catalog <> ''")

Darüber hinaus werde ich die Verwendung von Funktionen vorkonfigurieren, um dem MySQL-Befehl einfach Optionen hinzuzufügen, ohne Ihr gesamtes Skript ändern zu müssen.

function MysqlQuery() {
    mysql -h abcdcef.com --port=3306 --user=root --password=hbbfe --batch --skip-column-names -D "$1" -e "$2";
}

va=$(MysqlQuery Shop "SELECT COUNT(*) FROM shop_tab WHERE catalog <> ''")
vaABC=$(MysqlQuery Shop "SELECT COUNT(*) FROM shop_tab WHERE catalog <> 'abc'")
vadef=$(MysqlQuery Shop "SELECT COUNT(*) FROM shop_tab WHERE catalog <> 'def'")
# ...

Ich finde das auch lesbarer...