- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为了能够在一个数据库中创建应用程序的不同实例,例如测试阶段,我想使用变量作为模式名称。创建表或序列时一切正常,但我想不出一种在函数内部使用变量的优雅方法。我已经阅读了一些文章关于美元引用的字符串常量,但我仍然希望找到解决方案。
目前正在运行 PostgreSQL 11。
代码如下:
按预期工作,将 schema_name 设置为 sc 并在 DDL 期间使用该变量:
\set schema_name sc
CREATE SEQUENCE :schema_name.S_VT_KEY INCREMENT BY 1 START WITH 1 CACHE 1 NO CYCLE OWNED BY NONE;
create table :schema_name.vartest (
VT_KEY BIGINT,
DESCRIPTION TEXT);
现在函数:
create or replace function :schema_name.fvartest(
p_desc TEXT)
RETURNS bigint
language 'plpgsql'
COST 100.0
VOLATILE NOT LEAKPROOF
AS $function$
DECLARE
p_key bigint;
BEGIN
select nextval('sc.S_VT_KEY') into p_key; -- (1)
insert into sc.vartest (VT_KEY, DESCRIPTION) -- (2)
values (p_key, p_desc);
return p_key;
END $function$;
案例(1)我想使用类似的东西:
select nextval(:schema_name || '.S_VT_KEY') into p_key;
案例(2)
insert into :schema_name.vartest (VT_KEY, DESCRIPTION) -- (2)
到目前为止,任何变体都会呈现错误消息:
直接使用:
select nextval(:schema_name || '.S_VT_KEY') into p_key;
呈现语法错误
psql:test/testcase001.sql:29: ERROR: syntax error at or near ":"
LINE 12: select nextval(:schema_name || '.S_VT_KEY') into p_key; -- ...
转义,编译但不运行:
select nextval($e$:schema_name$e$ || '.S_VT_KEY') into p_key; -- (1)
CONTEXT: SQL statement "select nextval($e$:schema_name$e$ || '.S_VT_KEY')"
几乎就在那里,使用相同的定界符,替换变量但确实呈现语法错误:
select nextval($function$ :'schema_name' $function$ || '.S_VT_KEY') into p_key; -- (1)
LINE 12: select nextval($function$ 'sc' $function$ || '.S_VT_KEY')
也许 PostgreSQL 12 有办法?
最佳答案
我想出了一个目前可行的解决方案,但目前还不够优雅。我正在使用 bash 变量替换,它似乎适用于上述两种情况:
#!/bin/bash
export schema_name="sc"
psql postgresql://<user>:<pwd>@<host>/<db> << EOF
create or replace function ${schema_name}.fvartest(
p_desc TEXT)
RETURNS bigint
language 'plpgsql'
COST 100.0
VOLATILE NOT LEAKPROOF
AS \$function\$
DECLARE
p_key bigint;
BEGIN
select nextval('${schema_name}.S_VT_KEY') into p_key; -- (1)
insert into ${schema_name}.vartest (VT_KEY, DESCRIPTION) -- (2)
values (p_key, p_desc);
return p_key;
END \$function\$;
select ${schema_name}.fvartest('bla bla');
select * from ${schema_name}.vartest;
EOF
但现在我必须将代码放入 bash 脚本中并转义 $function$ Postges 风格的 $$ 符号。也许还有更好的方法,很想听听您的意见。
关于postgresql - plpgsql 函数中的变量替换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58735769/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!