sql >> Databasteknik >  >> RDS >> Mysql

Problem med returvariabel i bash

Ett enklare sätt är:

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

Dessutom kommer jag att förbereda användningen av funktionen för att enkelt lägga till alternativ till MySQL-kommandot utan att behöva ändra alla dina skript.

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'")
# ...

Jag tycker också att detta är mer läsbart...



  1. Konvertera 'smalldatetime' till 'datetimeoffset' i SQL Server (T-SQL-exempel)

  2. PostgreSQL listvyer

  3. finns det ett sätt att lista alla reserverade ord i mysql med hjälp av mysql kommandoradsverktyg

  4. Kan jag få en unik TIMESTAMP för varje post i MySQL