首页 文章

我收到这些错误,不明白如何解决

提问于
浏览
0
  • 错误(25,1):PLS-00103:遇到符号"EXEC"

  • 错误(30,1):PLS-00103:遇到以下其中一项时遇到符号"SELECT":begin function pragma procedure子类型当前游标删除存在先前符号"begin"替换"SELECT"继续 .

  • 错误(30,22):PLS-00103:当遇到以下情况之一时遇到符号"end-of-file" :(如果循环模式为空循环异常退出,则返回选择更新,同时使用<< continue close current delete fetch lock insert open rollback savepoint set sql execute commit forall merge pipe purge

DROP TABLE学生;承诺;

CREATE TABLE Student(
    studentNumber INT NOT NULL,
    studentName VARCHAR2(20) NOT NUll,
    gender CHAR(1) NOT NULL,
    highSchoolAvg INT NOT NULL,
    scholarship INT DEFAULT 0,
    CONSTRAINT "student_gender" CHECK (gender IN ('M', 'F')),
    CONSTRAINT "student_highSchoolAvg" CHECK (highSchoolAvg BETWEEN 0 AND       100)
);

CREATE OR REPLACE PROCEDURE AcceptStudent(
    studentNumberPR INT,
    studentNamePR VARCHAR2,
    genderPR CHAR,  
    highSchoolAvgPR INT)
IS
    ScholarshipPr INT;
BEGIN
    ScholarshipPR := 0;

    IF highSchoolAvgPR >= 90 and highSchoolAvgPR <=100 THEN
        ScholarshipPR := 1500;

    ELSIF highSchoolAvgPR >= 85 and highSchoolAvgPR < 90 THEN
        ScholarshipPR := 1000;

    ELSE
       raise_application_error(-20201, 'Invalid highSchool average');
    END IF;

    INSERT INTO Student (studentNumber, studentName, gender,     highSchoolAvg, scholarship) 
        VALUES (studentNumberPR, studentNamePR, genderPR,     highSchoolAvgPR, ScholarshipPr);
END;

exec ACCEPTSTUDENT (1, 'Ashley', 'F', 87);
exec ACCEPTSTUDENT (2, 'Will', 'M', 76);
exec ACCEPTSTUDENT (3, 'David', 'M', 94);
--Holly should be the only error--
exec ACCEPTSTUDENT (4, 'Holly', 'F', 103);
select * from student;

1 回答

  • 0

    您是否尝试从脚本执行所有操作?在程序之后,您在单独的行上缺少斜杠 / .

相关问题