oracle ora 01007,oracle - ORA-01007:变量不在选择列表中 - 堆栈内存溢出

我试图通过返回选择查询将多个值插入到特定表中,但我无法将其插入表中。如果我在某个地方做错了,请告诉我。

create or replace PROCEDURE DE_DUP_PROC1 (Dy_File_Name IN VARCHAR2,

SUPPLIER_CD IN VARCHAR2,

EXT_PHARMA_ID IN VARCHAR2,

FLAG_VALUE IN VARCHAR2,

ERR_COUNT IN VARCHAR2,

OUTPUT_STATUS OUT NUMBER)

AS

c2 SYS_REFCURSOR;

De_Dub_rec1 VARCHAR2 (2000);

v_sql VARCHAR2 (2000);

v_sql1 VARCHAR2 (2000);

ORGNIZATION_ID NUMBER(20);

PHARMACY_ID NUMBER(38);

v_dup_count VARCHAR2 (2000);

SRC_ID NUMBER(38);

DE_DUP_COUNT NUMBER(38);

DE_REC_COUNT1 NUMBER(10) := 3;

TYPE rec_typ IS RECORD

(

OLD_TRANS_GUID VARCHAR2 (255),

R_DSPNSD_DT DATE,

DETL_CLMNS_HASH1 VARCHAR2(255),

KEY_CLMNS_HASH1 VARCHAR2(255),

SUPPLIER_PHARMACY_CD1 VARCHAR2(200)

);

De_Dub_rec rec_typ;

BEGIN

IF DE_REC_COUNT1 > 0

THEN

OUTPUT_STATUS := 0;

dbms_output.put_line(OUTPUT_STATUS);

ELSE

SRC_ID := SRC_FILE_ID_SEQ.nextval

OPEN c2 FOR

( ' SELECT S.TRANS_GUID AS OLD_TRANS_GUID,S.DETL_CLMNS_HASH AS DETL_CLMNS_HASH1 ,S.KEY_CLMNS_HASH AS KEY_CLMNS_HASH1,S.RX_DSPNSD_DT AS R_DSPNSD_DT,

S.SUPPLIER_PHARMACY_CD AS SUPPLIER_PHARMACY_CD1 FROM (SELECT stg.*, row_number() over (partition BY key_clmns_hash ORDER BY 1) AS RN FROM

' || Dy_File_Name || ' stg ) s JOIN ps_pharmacy p ON s.extrnl_pharmacy_id = p.extrnl_pharmacy_id LEFT JOIN ps_rx_hist H

ON h.key_clmns_hash = s.key_clmnS_hash

AND h.rx_dspnsd_dt = s.rx_dspnsd_dt

AND s.supplier_pharmacy_cd = h.SUPPLIER_PHARMACY_CD

WHERE S.RN > 1

OR s.detl_clmns_hash = h.detl_clmns_hash ' );

LOOP

FETCH c2 INTO De_Dub_rec;

EXIT WHEN c2%NOTFOUND;

insert into PS_RX_DUPES(TRANS_GUID,DETL_CLMNS_HASH,KEY_CLMNS_HASH,RX_DSPNSD_DT,SUPPLIER_PHARMACY_CD,SRC_FILE_ID)

values(De_Dub_rec.OLD_TRANS_GUID,De_Dub_rec.DETL_CLMNS_HASH1,De_Dub_rec.KEY_CLMNS_HASH1,De_Dub_rec.R_DSPNSD_DT,De_Dub_rec.SUPPLIER_PHARMACY_CD1,SRC_ID);

commit;

END LOOP;

OUTPUT_STATUS := 1;

dbms_output.put_line(OUTPUT_STATUS);

END IF;

END DE_DUP_PROC1;

每当我执行上面的存储过程时,我下面的错误

declare

OUTPUT_STATUS number(2);

begin

DE_DUP_PROC1('T_MCL_10622_20150317_01526556','MCL','10622','BD','3',OUTPUT_STATUS);

end;

Error at line 1

- ORA-01007: variable not in select list

ORA-06512: at "PS_ADMIN.DE_DUP_PROC1", line 53

ORA-06512: at line 6

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值