欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

关于oracle触发器的迷惑

更新时间: 2014-01-05 02:15:45 责任编辑: Author_N1

 

关于oracle触发器的疑惑。
所用到的表:

  create table Students
  (
  SNO varchar(20),
  SNAME varchar(6),
  SEX varchar(2),
  BDATE date,
  HEIGHT int,
  DEPARTMENT varchar(12),
  primary key(SNO)
  );

create table Courses
(
CNO varchar(12),
CNAME varchar(12),
LHOUR int,
CREDIT int,
SEMESTER varchar(8),
primary key(CNO)
);

  create table SC
  (
  SNO varchar(20),
  CNO varchar(12),
  GRADE int,
  primary key(SNO,CNO),
  foreign key(SNO) references Students,
  foreign key(CNO) references Courses
  );

create table credits
(
sno varchar(20),
sumcredit int,
nopass int,
primary key(sno)
);
要求:
    当在SC表中插入一条选课成绩,自动触发Upd_Credit,完成在Credits表中修改该学生的合计学分数和不及格的课程数。
代码如下:
create trigger upd_credit after insert on sc
for each row
declare 
temp courses.grade%type;
begin
select credit into temp
from courses
where :new.cno=cno;

update credits
set sumcredit=sumcredit+temp
where :new.sno=sno;

if :new.grade<60 then 
update credits
set nopass=nopass+1
where :new.sno=sno;
end if;

end;

--提示创建的触发器带有编译错误。

刚上手,不知道怎个写法。还有就是,分号是在什么情况下,添加在哪里的。求指导。
--参考方法--
courses表有grade字段??
上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 02:15:45
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/7689/
本文WWW.DOC100.NET DOC100.NET版权所有。