tho*_*osh 4 postgresql variables bash psql
我已经搜索了一段时间,但似乎找不到明确的答案...我试图从终端运行 psql 脚本,同时传递表变量名称和另一个变量作为 psql 脚本的一部分。
bash 命令:
psql db1 -U user1 -f '/.../Desktop/.../sample.sql' -v table=pg2 -v v1="'2018-02-01'";
Run Code Online (Sandbox Code Playgroud)
PSQL 脚本:
SELECT count(*) FROM :table WHERE datekey = :v1;
Run Code Online (Sandbox Code Playgroud)
以上有效。但是,我希望能够将表名和附加变量转换为脚本本身中的字符串,以便我可以在我定义的另一个函数中使用它。例如,我希望 pg2 的表名可以作为字符串“pg2”使用。与 datekey 变量类似的要求。这可能吗?我的观察是,只有在 CRUD 操作或 WHERE 子句中使用时才可以传递变量。
从你的问题中我得到的是对 bash 中变量的作用的误解。尝试以下脚本是否有帮助:
#!/bin/bash
user="user1"
sqlfile='/.../Desktop/.../sample.sql'
table='pg2'
v1="'2018-02-01'"
psql db1 -U "$user" -f "$sqlfile" -v table=$table -v v1="$v1"
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
10112 次 |
| 最近记录: |