这是我正在尝试的bash脚本行:
psql -c 'GRANT ALL PRIVILEGES ON DATABASE "$PROJECT_ID" to "$PROJECT_ID";'
正如预期的那样,它不起作用,因为bash不会解释单引号内的任何内容。交换单引号和双引号不会出于同样的原因。
解决方案?
编辑:我所说的关于交换的内容并不正确 - 这对我来说是一个糟糕的假设;但是,由于确保psql语句仍然有效,所以不想交换。答案 0 :(得分:5)
如果您确定此SQL语句中的双引号是正确的:
psql -c 'GRANT ALL PRIVILEGES ON DATABASE "'"$PROJECT_ID"'" to "'"$PROJECT_ID"'";'
以下是其工作原理:字符串引用shell是在逐个字符的基础上完成的;我们不需要以相同的方式引用整个字符串,因此可以将几个不同引用的字符串子集连接在一起。
在这种情况下,这些子串是:
'GRANT ALL PRIVILEGES ON DATABASE "'
"$PROJECT_ID"
'" to "'
"$PROJECT_ID"
'";'
因此,当我们想要将文字"
作为字符串的一部分传递时,我们将它用单引号括起来;当我们想要扩展变量时,我们将它放在双引号中。