Oracle PLS-00225:子程序或游标';CHR';引用超出范围

Oracle PLS-00225:子程序或游标';CHR';引用超出范围,oracle,plsql,Oracle,Plsql,我在plsql中创建了一个过程,它返回这个错误任何人都知道我在这里发布了我的代码和错误快照 这是我的程序,我大部分时间都在做子查询,但这次它会返回这种错误。 我认为这个错误显示了一些关于别名的问题,但我已经为每个列定义了别名 我读了这篇文章,但我的代码仍然卡住了 这是我的桌子结构 CREATE TABLE CHR.CHR_TA_EMP_SWIPE_IN_OUT ( EMPLOYEE_ID NUMBER(10) NOT NULL, SWIP

我在plsql中创建了一个过程,它返回这个错误任何人都知道我在这里发布了我的代码和错误快照

这是我的程序,我大部分时间都在做子查询,但这次它会返回这种错误。 我认为这个错误显示了一些关于别名的问题,但我已经为每个列定义了别名 我读了这篇文章,但我的代码仍然卡住了

这是我的桌子结构

CREATE TABLE CHR.CHR_TA_EMP_SWIPE_IN_OUT
(
  EMPLOYEE_ID       NUMBER(10)                  NOT NULL,
  SWIPE_DATE        DATE                        NOT NULL,
  SWIPE_TIME        DATE                        NOT NULL,
  SWIPE_ID          NUMBER(10)                  NOT NULL,
  SWIPE_TYPE        VARCHAR2(1 BYTE),
  CREATED_BY        NUMBER(10),
  CREATION_DATE     DATE,
  LAST_UPDATED_BY   NUMBER(10),
  LAST_UPDATE_DATE  DATE,
  IS_MANUAL         VARCHAR2(1 BYTE),
  REASON_LKP        NUMBER(10),
  CLIENT_IP         VARCHAR2(50 BYTE),
  IS_REQUESTED      VARCHAR2(1 CHAR),
  TERMINAL_ID       VARCHAR2(50 BYTE),
  ATT_ID_REF        NUMBER
)

CREATE TABLE CHR.CHR_EMGT_EMPLOYEE
(
  EMPLOYEE_ID                NUMBER(10)         NOT NULL,
  EMPLOYEE_CODE              VARCHAR2(30 BYTE)  NOT NULL
  )



CREATE TABLE CHR.INOUT_LIVE_MACHINE_TEST 
(
  ATT_ID         NUMBER,
  USERID         NUMBER,
  EMPLOYEE_CODE  NUMBER,
  SENSORID       NUMBER,
  MACHINE_NUM    VARCHAR2(20 BYTE),
  CHECKTIME      VARCHAR2(20 BYTE),
  CHECKTYPE      VARCHAR2(20 BYTE)
)

你的程序没有错误。唯一的问题是在您的表“INOUT\u LIVE\u MACHINE\u TEST”中。它缺少“滑动日期”和“滑动时间”列。请参见下面的工作演示

创建了包含两列的表:

编译的过程:


您能从“过程CHR.ATT\U INSERT\U TEST”中删除CHR并重试一次吗..是的,我尝试了,但问题相同请发布表ddl以便我也可以检查..创建表语句请检查表结构第一个表和第三个表名称相同,INOUT\U LIVE\U机器测试和CHR\U EMGT\U员工的ddl丢失亲爱的问题仍然相同,我认为这个错误可能是由于程序特权造成的?我希望您也删除了CHR并运行了我的代码段..程序名中有CHR,它试图查找该用户,如果不存在,则抛出错误。它不能是私有问题,因为它的显示超出了范围。
CREATE TABLE CHR.CHR_TA_EMP_SWIPE_IN_OUT
(
  EMPLOYEE_ID       NUMBER(10)                  NOT NULL,
  SWIPE_DATE        DATE                        NOT NULL,
  SWIPE_TIME        DATE                        NOT NULL,
  SWIPE_ID          NUMBER(10)                  NOT NULL,
  SWIPE_TYPE        VARCHAR2(1 BYTE),
  CREATED_BY        NUMBER(10),
  CREATION_DATE     DATE,
  LAST_UPDATED_BY   NUMBER(10),
  LAST_UPDATE_DATE  DATE,
  IS_MANUAL         VARCHAR2(1 BYTE),
  REASON_LKP        NUMBER(10),
  CLIENT_IP         VARCHAR2(50 BYTE),
  IS_REQUESTED      VARCHAR2(1 CHAR),
  TERMINAL_ID       VARCHAR2(50 BYTE),
  ATT_ID_REF        NUMBER
)

CREATE TABLE CHR.CHR_EMGT_EMPLOYEE
(
  EMPLOYEE_ID                NUMBER(10)         NOT NULL,
  EMPLOYEE_CODE              VARCHAR2(30 BYTE)  NOT NULL
  )



CREATE TABLE CHR.INOUT_LIVE_MACHINE_TEST 
(
  ATT_ID         NUMBER,
  USERID         NUMBER,
  EMPLOYEE_CODE  NUMBER,
  SENSORID       NUMBER,
  MACHINE_NUM    VARCHAR2(20 BYTE),
  CHECKTIME      VARCHAR2(20 BYTE),
  CHECKTYPE      VARCHAR2(20 BYTE)
)
CREATE TABLE INOUT_LIVE_MACHINE_TEST 
(
  ATT_ID         NUMBER,
  USERID         NUMBER,
  EMPLOYEE_CODE  NUMBER,
  SENSORID       NUMBER,
  SWIPE_DATE        DATE                        NOT NULL,
  SWIPE_TIME        DATE                        NOT NULL,
  MACHINE_NUM    VARCHAR2(20 BYTE),
  CHECKTIME      VARCHAR2(20 BYTE),
  CHECKTYPE      VARCHAR2(20 BYTE)
)
CREATE OR REPLACE PROCEDURE ATT_INSERT_TEST
IS
   CURSOR ATT
   IS
      SELECT   emp.EMPLOYEE_ID EMPLOYEE_ID,
         io.CHECKTYPE CHECKTYPE,
         io.MACHINE_NUM MACHINE_NUM,
         io.ATT_ID ATT_ID, 
         io.SWIPE_DATE SWIPE_DATE,
         io.SWIPE_TIME SWIPE_TIME
  FROM   INOUT_LIVE_MACHINE_TEST io, CHR_EMGT_EMPLOYEE emp
 WHERE   emp.EMPLOYEE_CODE = io.EMPLOYEE_CODE
 AND io.ATT_ID NOT IN (SELECT   ATT_ID_REF
                                 FROM   CHR_TA_EMP_SWIPE_IN_OUT
                                WHERE   io.ATT_ID = ATT_ID_REF);
BEGIN
   FOR I IN ATT
   LOOP
      INSERT INTO CHR_TA_EMP_SWIPE_IN_OUT (EMPLOYEE_ID,
                                           SWIPE_DATE,
                                           SWIPE_TIME,
                                           SWIPE_ID,
                                           SWIPE_TYPE,
                                           CREATED_BY,
                                           CREATION_DATE,
                                           CLIENT_IP)
        VALUES   (I.EMPLOYEE_ID,
                  TO_DATE (i.SWIPE_DATE, 'MM/DD/YYYY'),
                  I.SWIPE_TIME,
                  CHR_TA_SWIPE_IN_OUT_SEQ.NEXTVAL,
                  I.CHECKTYPE,
                  I.EMPLOYEE_ID,
                  TO_DATE (i.SWIPE_DATE, 'MM/DD/YYYY'),
                  '192.168.0.71'
                  );
   END LOOP;
COMMIT;
END;
/