シェル スクリプトで 2 つのファイルのデータ型を比較しているときにエラー メッセージが表示されない

シェル スクリプトで 2 つのファイルのデータ型を比較しているときにエラー メッセージが表示されない

データ型を比較す​​る必要があります。データ型を含む .txt ファイルを作成し、クエリを記述して、Netezza システム テーブル (Netezza データベースを使用) からデータ型を取得し、.TXT ファイルにエクスポートしました。また、diff -q不一致がある場合は強調表示するコマンドを使用しました。実際には、一致する場合は常に正しい結果が得られますが、不一致がある場合は強調表示されません。期待どおりの結果を得るために、正しいエコー エラー メッセージなどを提供しなかった可能性があります。合計 10 個のファイルをチェックする必要があるため、for ループを使用しました。

以下のコードを試してみましたが、簡単なロジックや洞察があれば助かります。

for <condition>
do
TABLE_ddl="SELECT TYPE_NAME FROM SYSTEM.._V_SYS_COLUMNS WHERE TABLE_NAME = '${TABLENAME}name';
echo ${TABLE_ddl};

CURRENT_TEMP_DDL=`nzsql -h ${hostname} -db ${database} -u ${username} -pw ${password} -A -t -o ${PATH}/${TABLENAME}_TABLE.TXT -c "${TABLE_ddl}"`
echo ${CURRENT_TABLE_DDL};
done

CHECK=`diff -q ${PATH}/${TABLENAME}_FILE.txt ${PATH}/${TABLENAME}_TABLE.TXT`;

そして、以下のような出力を期待しています。

tablename
CURRENT_TEMP_DDL #Query which should reflect with table name
datatypes matched
For ex. 
employee
select type_name from system.._v_sys_columns where table_name = 'employee' and database =<dbname>
datatypes matched for employee_FILE.txt and employee_TABLE.TXT

department
select type_name from system.._v_sys_columns where table_name = 'department' and database =<dbname>
datatypes unmatched for department_FILE.txt and department_TABLE.TXT

答え1

2 つのファイルの違いを「強調表示する」とは正確には何を意味するのかわかりませんが、diff2 つのファイルの違いを表示するには次のように使用できます。

diff file1 file2 | grep "<" | sed 's/^<//g'標準出力に表示する

結果は次のようになります:

skywalker@endor:~/scripts/python/proxyupdate$ diff proxyupdate.py proxyupdate.bak | grep "<" | sed 's/^<//g'
 #this line is added for testing

または

diff file1 file2 | grep "<" | sed 's/^<//g' > file3.txt新しいファイルに書き込みます。

または、以下も試すことができますsort:

sort file1 file2 | uniq -u

同じ結果が生成されます。

skywalker@endor:~/scripts/python/proxyupdate$ sort proxyupdate.py proxyupdate.bak | uniq -u
#this line is added for testing

関連情報