如何将PostgreSQL结果插入shell变量

问题描述 投票:1回答:2

我想在变量中设置所有这些语法

su -l postgres -c "psql -c \"CREATE DATABASE graphite WITH OWNER graphite\""

CREATE DATABASE 

所以我写了这个

res=$(  su -l postgres -c "psql -c \"CREATE DATABASE graphite WITH OWNER graphite\"" )

CREATE DATABASE 

但$ res是空的

echo $res

我也尝试添加“”但没有成功。

如何插入结果

su -l postgres -c "psql -c \"CREATE DATABASE graphite WITH OWNER graphite\""

一个shell变量?

bash postgresql shell variables psql
2个回答
1
投票

检查生成的退出状态是否有效:

MacBook-Air:~ root# res=$(su -l vao -c "/usr/local/Cellar/postgresql/9.6.1/bin/psql -c \"CREATE DATABASE graphite\" -d so")
MacBook-Air:~ root# echo $?
0
MacBook-Air:~ root# res=$(su -l vao -c "/usr/local/Cellar/postgresql/9.6.1/bin/psql -c \"CREATE DATABASE graphite\" -d so")
ERROR:  database "graphite" already exists
MacBook-Air:~ root# echo $?
1

和stdout也显示:

MacBook-Air:~ root# echo $res
Timing is on. Pager usage is off. SET Time: 0.333 ms SET Time: 0.112 ms SET Time: 0.127 ms Time: 0.290 ms

0
投票

这是一个更通用的答案,但反引号(`)会将任何shell命令的结果放入变量中:

$ foo=`psql -d postgres -c "select 'Hello'"`
$ echo $foo
?column? ---------- Hello (1 row)

也就是说,我很好奇你为什么要在shell变量中使用create database命令的结果。我确信这是有充分理由的,我绝不会想到做这样的事情。

© www.soinside.com 2019 - 2024. All rights reserved.