开头还是介绍一下群,如果感兴趣polardb ,mongodb ,mysql ,postgresql ,redis 等有问题,有需求都可以加群群内有各大数据库行业大咖,CTO,可以解决你的问题。加群请联系 liuaustin3 ,在新加的朋友会分到2群(共820人左右 1 + 2 + 3)新人会进入3群,进瑞典马工群的单独说。

最近有人问,想通过SHELL 来传入变量到 PSQL的SQL 语句中,如何去撰写,因为他写的程序老是有问题。PSQL 命令中被经常DISS的问题除了不能带有密码外,就是这个问题了,变量。

怎么在PSQL 外部将变量设置,并传入到POSTGRESQL命令行内,我们做一个例子:

psql -X -v a=b

\echo THE VALUE OF VAR a IS :a

psql -X --set=a=c

举例:我们想将多个字段传入到PG内,可以将多个值进行引号设置即可

[postgres@pg_qixun ~]$ psql -X -v a='postgresql EDB enterprise database'

psql (14.7)

Type "help" for help.

postgres=# \echo The variable a is :a

The variable a is postgresql EDB enterprise database

下面我们举一个复杂的例子

我们的变量在一个文本中,而我们要执行的脚本在另一个文件中

psql -x -v a="$( cat file.txt )" -f show.sql

而如果你有一个更复杂的执行方式,如同下面的这个例子

[postgres@pg_qixun ~]$ cat show.sql

select * from :a limit 1;

[postgres@pg_qixun ~]$ psql -X -v a="$( cat file.txt )" -v b='select version();' -f show.sql

oid  | datname  | datdba | encoding | datcollate  |  datctype   | datistemplate | datallowconn | datconnlimit | datlastsysoid | dat

frozenxid | datminmxid | dattablespace | datacl

-------+----------+--------+----------+-------------+-------------+---------------+--------------+--------------+---------------+----

----------+------------+---------------+--------

13892 | postgres |     10 |        6 | en_US.UTF-8 | en_US.UTF-8 | f             | t            |           -1 |         13891 |

1201 |          1 |          1663 |

(1 row)

version

---------------------------------------------------------------------------------------------------------

PostgreSQL 14.7 on x86_64-pc-linux-gnu, compiled by gcc (GCC) 4.8.5 20150623 (Red Hat 4.8.5-44), 64-bit

(1 row)

[postgres@pg_qixun ~]$ psql -X -v a=1 -v b=2 -v c=3 -v d=4  -f show.sql

datname

----------

postgres

(1 row)

datname

-----------

postgres

dvdrental

(2 rows)

datname

-----------

postgres

dvdrental

template1

(3 rows)

datname

-----------

postgres

dvdrental

template1

template0

(4 rows)

[postgres@pg_qixun ~]$ cat show.sql

select datname from pg_database limit :a;

select datname from pg_database limit :b;

select datname from pg_database limit :c;

select datname from pg_database limit :d;

以上为将变量带入查询中的一些简单的操作,而在POSTGRESQL 有一部分情况是通过将变量带入到函数中的,我们下面举一个例子来看看如何将变量带入到函数,我们简单的写一个函数,来进行当前PG实例中有多少数据库的一个计算,但是我们查询的是符合我们要求的PG的数据库的数量,或者判断符合我们名字要求的PG是否存在于

CREATE OR REPLACE FUNCTION count_db(IN var_b varchar(20)) RETURNS INT8 AS $$

DECLARE

v_int INT4;

BEGIN

SELECT COUNT(*) INTO v_int FROM pg_database WHERE datname like var_b;

RETURN v_int;

$$ LANGUAGE plpgsql;

然后我们从外部来调用这个函数并赋予变量

方法1  失败

[postgres@pg_qixun ~]$ psql -X -v a=postgres%   -c 'select count_db(:a)'

ERROR:  syntax error at or near ":"

LINE 1: select count_db(:a)

方法2 失败

psql -X -v a="postgres%"   -c 'select count_db(:a)'

ERROR:  syntax error at or near ":"

LINE 1: select count_db(:a)

方法3 失败

[postgres@pg_qixun ~]$ psql -X -v a="postgres%"   -f show.sql

psql:show.sql:1: error: invalid command \SET

psql:show.sql:2: ERROR:  syntax error at or near ")"

LINE 1: SELECT count_db(postgres%);

[postgres@pg_qixun ~]$ cat show.sql

\SET a postgres%

SELECT count_db(:a);

后面又试过  4 5 6 7 8 种方案,均有问题。

最后经过查阅,如果要在外部调用函数,给出变量是不能单独写语句的,而是要用其他的方式来代替 -c  或 -f  调用命令的方式 ,具体的写法如下:

psql -X -v a="'postgres'" <<< 'select count_db(:a);'

开头还是介绍一下群,如果感兴趣polardb ,mongodb ,mysql ,postgresql ,redis 等有问题,有需求都可以加群群内有各大数据库行业大咖,CTO,可以解决你的问题。加群请联系 liuaustin3 ,在新加的朋友会分到2群(共820人左右 1 + 2 + 3)新人会进入3群,进瑞典马工群的单独说。最近有人问,想通过SHELL 来传入变量到 PSQL的SQL 语句中,如...
PostgreSQL 保存和还原 查询 计划 sr_plan看起来像Oracle Outline系统。 它可以用来锁定执行计划。 如果您不信任计划者或不能制定更好的计划,则很有必要。 make USE_PGXS=1 make USE_PGXS=1 install 并修改您的postgres配置: shared_preload_libraries = 'sr_plan' 在 数据库 安装扩展: CREATE EXTENSION sr_plan; 如果要保存 查询 计划,则必须设置 变量 : set sr_plan . write_mode = true; 现在,所有后续
plpgsql 变量 类型及对应关系 1、PLpgSQL_datum.dtype共有5 类型,其 2 类型属于通用类型,覆盖pg_type 所有类型:由plpgsql_build_variable 函数 根据pg_type 查到的类型决定(对应关系见下表 的PLPGSQL_DTYPE_VAR、PLPGSQL_DTYPE_REC) 2、后四种类型单独应.
set session “unit.name” to “张三”;select current_setting(‘unit.name’)更多:https://www.jb51.net/article/204214.htm 根据父级 查询 子级 根据子级 查询 父级 从父级到子级 方法 函数 实现夸库 查询 数学 函数 abs(x) abs(-17.4) cbrt(double) cbrt(27.0) ceil(do
1、此电脑–》右键属性–》高级系统设置–》环境 变量 2、将bin目录放到Path :你的安装目录/bin;,注意前后分号隔开3、新建一个PGDATA的系统 变量 ;4、初始化 数据库 管理员身份 cmd运行:initdb.exe -D D:\webapp\pgsql-10.20\data -E UTF-8 --locale=chs -U postgres -W或者将已有的data文件放到pgsql的安装目录下,注意要修改一些 postgresql .conf的内容.5、注册window服务 pg_ctl.exe regi
用pgAdminIII连接服务器后,点击模式-&gt;public-&gt;数据表-&gt;找到自己想操作的表,在上面右击: 1、手动插入数据。如果想手动插入数据,则点击【查看数据】-&gt;查看所有行,会跳出一个框,可以在这个框里手动编辑一些数据,像SQL SERVER一样。 2、脚本插入。如果想用脚本插入数据,则点击【脚本】-&gt;S...
本文实现了一个按照指定百分位的数据生成等距的序列值,分位数的数据按照每增长一个百分点分一组,如果分组的数据没有值自动会合并到下一组,直到满足条件的分组,上限100组哦. TODO优化:动态分组,并且不限制分组数量. 思路1 将分组后的数据进行自关联(需要转成行记录),拿到本组以及下一个分组的数值,然后和需要分组的表进行关联 当需要分组的字段落地对应的分组区间的时候(此处采用不等值连接,不知道...
今天我们要探讨的是 custom执行计划和通用执行计划。这一技术在 Oracle 被称为绑定 变量 窥视。但 Kingbase 并没有这样的定义,更严格地说,Kingbase叫做custom执行计划和通用执行计划。 什么是custom执行计划,什么是通用执行计划,我们先来看一个例子,我创建了一个100011行的表,其 有两列分别为 id、 name。在name列就2种类型的值,一种值为“aaa”,有...
,`variable_name`是您要设置的 变量 名,`value`是 变量 的值。 例如,要将 变量 `my_var`设置为字符串`hello`,可以 使用 以下 命令 : \set my_var 'hello' 要将 变量 `my_var`设置为整数`42`,可以 使用 以下 命令 : \set my_var 42 您还可以在 查询 使用 变量 。例如,要 使用 变量 `my_var`的值,可以 使用 以下语法: SELECT * FROM my_table WHERE column_name = :'my_var'; 这将替换`:my_var`为 变量 `my_var`的值。