Запрос Postgresql в скрипте bash
У нас возникла проблема с запросом 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 ответ
Это не похоже на вывод ваших команд - вместо этого это какой-то отладочный вывод?
То, что у вас есть, выглядит правильно, в том смысле, что его можно подавать в оболочку и выдавать то, что вы просили. Обратите внимание, что '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' ...
,