- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
任何人都知道如何避免 PLS-00312 错误?
“PLS-00312:位置参数关联可能不遵循命名关联”
我得到这个是因为下面一行:
AttachList=> v_est_proc_name||'_EST_PROC.csv',v_prd_segs||'_PRD_SEGS.csv',
在下面的过程中:
create or replace procedure send_csv as
v_tomail varchar2(40);
v_est_proc_name varchar2(40);
v_prd_segs varchar2(40);
cursor c1 is
SELECT email_address
INTO v_tomail
FROM mail where
mdate = (select max(mdate) FROM blah)
group by email_address
order by max(mdate) desc;
begin
open c1;
fetch c1 into v_tomail;
SELECT tablename into v_est_proc_name
FROM blah_blah
WHERE
CREATED_AT = (select MAX(CREATED_AT) from blah);
SELECT tablename into v_prd_segs
FROM blah_blah
WHERE
CREATED_AT = (select MAX(CREATED_AT) from blah);
mail.send_mail.send(
ToList=> v_tomail,
Subject=> 'see attachments',
Body=> 'Please action the attached files for this request.',
FromEmail=> 'donotreply@mail.com',
FromHost=> 'host',
SMTPServer=> 'host',
AttachList=> v_est_proc_name||'_EST_PROC.csv',v_prd_segs||'_PRD_SEGS.csv',
Directory=> 'CSV_DIR');
End;
我只是不知道如何摆脱它...必须有办法。
最佳答案
消息是不言自明的。
假设您有一个过程或函数(让我们说一个过程,具体来说),my_proc
,有四个参数:
my_proc(param1, param2, param3, param4)
给定四个参数 arg1、arg2、arg3、arg4
的值,您可以这样调用过程:
my_proc(arg1, arg2, arg3, arg4)
-- 这使用位置 参数关联。参数的顺序有意义。
你也可以这样调用它:
my_proc(param1 => arg1, param3 => arg3, param2 => arg2, param4 => arg4)
-- 这使用命名 参数关联。 “关联”的顺序不再有意义 - 您可以按照您喜欢的任何顺序放置赋值(关联),只要您将正确的参数与正确的参数名称配对即可。
你也可以混合使用它们,但你只能先使用位置关联,然后再使用命名关联。这是合法的:
my_proc(arg1, arg2, param4 => arg4, param3 => arg3)
但这是非法的:
my_proc(arg1, param3 => arg3, param2 => arg2, arg4)
这有很好的理由,但理由无关紧要;这是您的代码必须遵循的语法要求,即使没有充分的理由。
在你的代码中,所有的关联都被命名,除了参数(值)
v_prd_segs||'_PRD_SEGS.csv'
未分配给特定的命名参数。
要修复它,请使用应该接受此参数的参数的名称,就像您对所有其他参数所做的那样。
关于sql - PLS-00312 : a positional parameter association may not follow a named association,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55016540/
我有一个 Oracle 数据库 12c Release 12.1.0.1.0 - 64 位生产数据库。我正在尝试通过公共(public) dblink (DEVICE_201) 在 Oracle Da
我正在使用 R 中的 plspm 包对信息安全的风险评估进行建模。但是,当我运行分析时,出现以下错误: Error in if (w_dif < specs$tol || iter == specs$
我正在制作一个使用流式传输的类似 radio 的应用程序。在这里,我需要从链接 (http://somedomain/some.pls) 流式传输音频。 我已经创建了 MediaPlayer 并且知道
我正在尝试创建这个函数: create or replace function g(sN int) return char(3) as t char(3); begin s
以下是我的oracle版本 Oracle 数据库 11g 企业版 11.2.0.2.0 版 - 64 位生产 我试图改变一个表来添加一列,但由于它花了很长时间,我取消了它。 一段时间后,我开始在所有引
我执行了创建下表的 PL/SQL 脚本 TABLE_NAME VARCHAR2(30) := 'B2BOWNER.SSC_Page_Map'; 我使用参数为这个表创建了一个插入函数 CREATE OR
我想将Rownum存储为变量,而不是使用昂贵的Join。 我需要从Select语句中获取此信息,因为Rownum在各种环境下都会有所不同,因此它不能是代码中的文字字符串。 对于上下文,此查询在Orac
刚刚完成编写将错误记录到表中的错误日志过程。我刚完成我的第一个异常处理程序,由于此错误,我无法编译该程序包。 我相信我在调用write_error_log过程时遇到此错误。 以下是包装中的代码。 CR
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic
尝试编译时出现以下错误 Error(16,8): PLS-00103: Encountered the symbol "SPROLLUPEXPENSEITEM" when expecting one
我在调用我的程序时遇到问题。甲骨文紧急暂停 PLS-00306 Error: Wrong number of types of arguments in call to procedure. 我的类型
收到与函数相关的以下错误: 'ERROR at line 20: PLS-00103: Encountered the symbol "end-of-file" when expecting one
我需要一些关于如何在我的jsp中使用jquery ajax的帮助,网上有很多例子,但它是基于php的,有些不涉及sql。 我的 jsp 中有 2 个选择框 Category
我创建了一个带有单选按钮的 CSS 图像 slider 来控制它。我已将单选按钮设置为 visibility: hidden并使用缩略图作为标签。 html 看起来像这样: 对其他缩略图重复
我想从网站播放 PLS 文件 ( http://live.radioguerrilla.ro:8002/listen.pls )。我想使用 HTML5 引入的 audio 标签,但我认为它不能从 PL
前几天编写一个存储过程,需要访问远程数据库的字段,于是建立一个dbLink并建了同义词: ?
我正在包中创建一个过程。我已经更新了包的规范,然后当我更新包的主体时,它向我显示以下错误。 [Error] PLS-00323 (314: 13): PLS-00323: subprogram or
请帮助我理解这个错误..可能是我必须执行 ud_mosh_dvig(x number, y number) 并在之后创建类型主体。 create or replace type CAR as obje
这个包有什么问题,因为它给出了错误? CREATE OR REPLACE PACKAGE PKG_SHOW_CUST_DETAILS AS PROCEDURE SHOW_CUST_DETAIL
在创建具有重载函数的包时,请帮助查找错误。 显示错误: PL-00103:在期待以下之一时遇到符号“NUMOU”:语言。 PL-00103:在预期以下情况之一时遇到符号“函数”:结束而不是编译指示最终
我是一名优秀的程序员,十分优秀!