& "psql" "-d" "yourdb" "-h" "localhost" "-p" "5432" "-U" "youruser" "-c" "select foo from bar where data @> `'{ `"key`" : `"value`" }`';"
错误:类型为json的输入语法无效 第1行:...来自bar的数据@> ' {key ...
如何转义该命令字符串以便psql
不会抛出?
答案 0 :(得分:2)
推荐的方法是使用Npgsql或psqlODBC驱动程序,因为它们在处理基本上所有内容(连接,参数,结果,错误......)时有许多优点。 / 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
。