Я делаю все в одинарных кавычках, чтобы не допустить странных расширений. Чтобы в строке была одинарная кавычка, я использую '\''
, как в ' string '\'' rest of string '
. Чтобы иметь переменную, я использую '"$var"'
, как в ' string '"$var"' rest of string
, чтобы она правильно раскрылась и соединилась с остальной частью строки.
Следующие работы:
> var=var
> echo "select dbms_metadata.get_ddl('PACKAGE'," |
> sed 's|\(select dbms_metadata.get_ddl('\''PACKAGE'\'',\).*|\1'\'"${var}"\'','\''PRC_BNE_JZ'\'') from dual;|'
select dbms_metadata.get_ddl('PACKAGE','var','PRC_BNE_JZ') from dual;
Но, вероятно, использовать "
, вероятно, проще в этом случае, так как строка везде использует '
, как в:
sed "s|\(select dbms_metadata.get_ddl('PACKAGE',\).*|\1'${var}','PRC_BNE_JZ') from dual;|"
Ошибка происходит из оболочки, которая не может проанализировать аргументы. Ex. для следующего:
> echo abc)
main.sh: line 2: syntax error near unexpected token `)'
main.sh: line 2: `echo abc)'
В вашей команде происходит следующее:
sed -i " bla bla "'${var}','PRC_BNE_JZ') from dual;"|" backup_script.sql
^^^^^^^^^^^^^^^^^
^^^^^^^^^^^^^ - could be 4th argument
^ - unquoted `)` is parsed by bash, as in subshell `( ... )`
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - 2nd argument
^^ - 1st argument to sed command
^^^ - run sed command