触发器语法错误问题【很简单的】
很基本的问题啦,请各位看看
在‘学生成绩’表中插入成绩时,根据视图‘学生所学课程及学分统计’中的一门课的学分数,相应的更新‘学生’表中的总学分
create trigger grade_count
on 学生成绩
for insert
as
declare @学号 char, @总学分 int
@学号 = inserted.学号 //获得插入成绩时的学号
@总学分=
select sum(学分) 总学分 //得到该学生的总学分数
from 学生所学课程及学分统计
where 学生所学课程及学分统计.学号=@学号
update 学生 //更新总学分
set 已修总学分=@总学分
where 学生.学号ww=@学号
///////////////////////////////////////////////////////////////////
//插入一条到‘学生成绩’表中
insert 学生成绩ww(学号ww,学期ww,课程名称ww,成绩ww,任课老师ww,专业ww)
values('200124450202','2','2','67','3','6')
go
///////////////////////////错误显示//////////////////////////////
服务器: 消息 170,级别 15,状态 1,过程 grade_count,行 10
第 10 行: '@学号' 附近有语法错误。
服务器: 消息 137,级别 15,状态 1,过程 grade_count,行 17
必须声明变量 '@总学分'。
(所影响的行数为 1 行)