Entnommen aus bash script - select from database into variable , können Sie das Abfrageergebnis in eine Variable einlesen.
Beispiel
mysql> SELECT * FROM domains;
+-------+---------+
| user | domain |
+-------+---------+
| user1 | domain1 |
| user2 | domain2 |
| user3 | domain3 |
+-------+---------+
Nutzung
$ myvar=$(mysql -D$MYDB -u$MYUSER -p$MYPASS -se "SELECT domain FROM domains")
$ echo $myvar
domain1 domain2 domain3
echo
ist der Bash-Befehl für die Ausgabe. Sie können dann $myvar
teilen in separate Variablen
:
$ read var1 var2 var3 <<< $myvar
$ echo $var1
domain1
$ echo $var2
domain2
Sie können diese beiden Befehle zu einem einzigen kombinieren:
read var1 var2 var3 <<< $(mysql -D$MYDB -u$MYUSER -p$MYPASS -se "SELECT domain FROM domains")
Es ist möglich, die Ergebnisse in Arrays zu speichern (nützlich, wenn Sie nicht wissen, wie viele Datensätze dort vorhanden sind):
$ read -ra vars <<< $(mysql -D$MYDB -u$MYUSER -p$MYPASS -se "SELECT domain FROM domains")
$ for i in "${vars[@]}"; do
$ echo $i
$ done
domain1
domain2
domain3