1

У нас возникла проблема с запросом postgresql bash. Вывод запроса из скрипта bash добавляет дополнительные кавычки вокруг даты. Пожалуйста, вы можете помочь мне исправить это ?!

Автор сценария:

#!/bin/sh

lastmonth=$(date -d "-1 month -$(($(date +%d)-1)) days" +%Y-%m-%d)
thismonth=$(date -d '-1 month -12 days' +%Y-%m-%d)

sudo -u postgres psql -d linetest_uptime -A -o /tmp/linetest_$(date +%Y-%m-%d).txt -c "select t.*, ip,port from line_test t,service_address s where '$thismonth' <= start and start < '$lastmonth' and service_address_id=s.id order by t.start,status desc" >/dev/null 2>&1 && sudo mv /tmp/linetest_$(date +%Y-%m-%d).txt /reporting/line_test_data/ && sudo chown $USER:$USER /reporting/line_test_data/linetest_$(date +%Y-%m-%d).txt

Выход:

sudo -u postgres psql -d linetest_watchdog -A -o /tmp/linetest_2014-03-13.txt -c 'select t.*, ip,port from line_test t,service_address s where '\''2014-02-01'\'' <= start and start < '\''2014-02-01'\'' and service_address_id=s.id order by t.start,status desc

Нам нужно удалить '\' '\', который теперь оборачивается вокруг переменной даты.

1 ответ1

0

Это не похоже на вывод ваших команд - вместо этого это какой-то отладочный вывод?

То, что у вас есть, выглядит правильно, в том смысле, что оно может быть подано в оболочку и дать то, что вы просили. Обратите внимание, что 'aaa'\''bbb' идентично "aaa'bbb" !

Примечание: ваши переменные выглядят немного сложнее, и вы повторяете $(date +%Y-%m-%d) ; следующее может помочь:

lastmonth=$(date -d "-1 month" +%Y-%m-01)
thismonth=$(date +%Y-%m-01)
today=$(date +%Y-%m-%d)

и SQL-запрос может быть более идиоматическим, как ... where date between '$lastmonth' and '$thismonth' ...

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .