Поймать ошибку команды psql (PostgreSQL) в bash, которую можно использовать универсально, независимо от SQL - PullRequest
0 голосов
/ 14 сентября 2018

Я хочу отловить ошибку PostgreSQL в bash.

Например:

function create_database:
    sudo -u postgres psql -c "CREATE DATABASE $1 WITH OWNER $2;"

Я хочу что-то, что может отлавливать ошибки любого типа postgres (не только для create) и echo ошибка

также в случае ошибки return 1

Если я использую: $RESULT=$(sudo -u postgres psql -c "CREATE DATABASE $1 WITH OWNER $2;")

Я получаю ответ от psql, но это относится коперация, поэтому я должен выполнить сопоставление строк для каждой команды SQL.

1 Ответ

0 голосов
/ 14 сентября 2018

Довольно просто увидеть, был ли оператор успешным или нет: просто проверьте код возврата.

$ sudo -u postgres psql -c 'melect 32'
ERROR:  syntax error at or near "melect"
LINE 1: melect 32
        ^
$ echo $?
1

$ sudo -u postgres psql -c 'DROP TABLE not_exists'
ERROR:  table "not_exists" does not exist
$ echo $?
1

$ sudo -u postgres psql -c 'SELECT 42'
 ?column? 
----------
       42
(1 row)

$ echo $?
0

Таким образом, ваш код может сделать что-то вроде этого:

sudo -u postgres psql -c "..." >/tmp/result 2>&1
if [ $? -ne 0 ]; then
    echo /tmp/result >>logfile
    rm -f /tmp/result
    exit 1
else
    rm -f /tmp/result
fi
...