从PowerShell运行时转义psql命令中的引号

时间:2017-08-16 11:21:09

标签: powershell psql

& "psql" "-d" "yourdb" "-h" "localhost" "-p" "5432" "-U" "youruser" "-c" "select foo from bar where data @> `'{ `"key`" : `"value`" }`';"
  

错误:类型为json的输入语法无效   第1行:...来自bar的数据@> ' {key ...

如何转义该命令字符串以便psql不会抛出?

1 个答案:

答案 0 :(得分:2)

推荐的方法是使用NpgsqlpsqlODBC驱动程序,因为它们在处理基本上所有内容(连接,参数,结果,错误......)时有许多优点。 / p>

但是,如果您坚持使用命令行客户端,则可以通过添加反斜杠来修复语法错误,以逃避嵌套的双引号以执行外部命令(反引号只是为PowerShell解析器转义它们): / p>

"SELECT foo FROM bar WHERE data @> '{ \`"key\`" : \`"value\`" }';"
#                                     ^     ^     ^       ^

单引号不需要转义。

我还建议使用splatting来传递参数:

$params = '-d', 'yourdb',
          '-h', 'localhost',
          '-p', 5432,
          '-U', 'youruser',
          '-c', "SELECT foo FROM bar WHERE data @> '{\`"key\`":\`"value\`"}';"

& 'psql.exe' @params

请注意,如果包含可执行文件的目录不在PATH环境变量中,则必须使用其(绝对或相对)路径调用psql.exe