xyTianZhao 2015-06-17 16:47 采纳率: 66.7%
浏览 3466
已采纳

用MySql的Navicat创建存储过程总是报1458错误

下面是我穿件存储过程的代码。求大神帮忙看看。真心很急,明天就要用。

 create procedure searchStudentGrade(in id char)
 begin
     if id is null
         select  student.StudentID,student.StudentName,student.ClassNumber,grade.ExamID,course.CourseName,grade.Grade,course.CourseID
        from student,grade,course
        where student.StudentID=grade.StudentID and grade.CourseID=course.CourseID;
    else
        select student.StudentID,student.StudentName,student.ClassNumber,grade.ExamID,course.CourseName,grade.Grade,course.CourseID
        from student,grade,course
        where student.StudentID=grade.StudentID and grade.CourseID=course.CourseID and grade.StudentID=id;
    end if;
end;
  • 写回答

2条回答 默认 最新

  • danielinbiti 2015-06-17 17:06
    关注
     create procedure searchStudentGrade(in id char)
     begin
         if id is null then 这里少了一个then吧
             select  student.StudentID,student.StudentName,student.ClassNumber,grade.ExamID,course.CourseName,grade.Grade,course.CourseID
            from student,grade,course
            where student.StudentID=grade.StudentID and grade.CourseID=course.CourseID;
        else
            select student.StudentID,student.StudentName,student.ClassNumber,grade.ExamID,course.CourseName,grade.Grade,course.CourseID
            from student,grade,course
            where student.StudentID=grade.StudentID and grade.CourseID=course.CourseID and grade.StudentID=id;
        end if;
    end;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?