我想在变量中设置所有这些语法
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变量?
检查生成的退出状态是否有效:
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
这是一个更通用的答案,但反引号(`)会将任何shell命令的结果放入变量中:
$ foo=`psql -d postgres -c "select 'Hello'"`
$ echo $foo
?column? ---------- Hello (1 row)
也就是说,我很好奇你为什么要在shell变量中使用create database
命令的结果。我确信这是有充分理由的,我绝不会想到做这样的事情。