シェルスクリプトのさまざまな変数に対してコマンドを実行する

シェルスクリプトのさまざまな変数に対してコマンドを実行する

したがって、SQLクエリから返された最初の列の値を変数(var)に格納します。 SQLクエリは複数の行を返し、後でこの値がコマンドに使用されるため、配列型でなければなりません。

シェルスクリプトで異なる変数を使用して同じコマンドを順番に実行する方法がわかりません。

var=`app/oracle/product/10.2.0/bin/sqlplus -s user/passwd<< !EOF!
  set pages 0 echo off feed off timing off
select entity_name,uid,set_date from table_name;
exit
     !EOF!`

実行するコマンドは次のとおりです。

X=$var Y=`date` ./test.sh

ベストアンサー1

あなたの要求は不明です。スクリプトを変更できますか?そうでない場合XY変数に明示的に依存する場合は、一時/ループ変数が必要です。test.sh各配列要素に対して実行するには、forループを試してみてください(要素に空白文字がない場合)。

for TMP in "${var[@]}"; do X="$TMP" Y=$(date) ./test.sh; done

おすすめ記事