创建一个after触发器,在student表中删除某学生的记录时,删除其相应的选课记录。
时间: 2024-02-21 14:57:14 浏览: 64
好的,以下是创建after触发器的SQL语句:
```
CREATE TRIGGER delete_student AFTER DELETE ON student
FOR EACH ROW
BEGIN
DELETE FROM selection WHERE student_id = OLD.student_id;
END;
```
解释一下:
- `delete_student` 是触发器的名称,可以自定义;
- `AFTER DELETE` 表示触发时机,即在`student`表中有记录被删除之后触发;
- `ON student` 表示在`student`表上创建触发器;
- `FOR EACH ROW` 表示触发器针对每一行数据都会执行;
- `DELETE FROM selection` 表示在`selection`表中删除符合条件的记录;
- `WHERE student_id = OLD.student_id` 表示删除`selection`表中`student_id`与`OLD`表中对应记录`student_id`相同的记录,`OLD`表示被删除的记录。
这样,在删除`student`表中某个学生记录时,就会自动删除其在`selection`表中的选课记录。
相关问题
oralce中创建一个after触发器,在student表中删除某学生的记录时,删除其相应的选课记录
在Oracle中创建一个after触发器可以通过以下步骤实现:
1. 创建一个名为`delete_student_trigger`的触发器并指定其在`student`表中的`DELETE`操作之后触发。
```sql
CREATE OR REPLACE TRIGGER delete_student_trigger
AFTER DELETE ON student
```
2. 定义一个触发器的主体,包括删除选课记录的SQL语句。在本例中,我们可以使用子查询来选择与被删除的学生相关的所有选课记录,并在`course_selection`表中将它们删除。
```sql
BEGIN
DELETE FROM course_selection
WHERE student_id = (SELECT id FROM deleted);
END;
```
3. 将触发器绑定到表中。
```sql
ALTER TRIGGER delete_student_trigger
ENABLE;
```
现在,当您从`student`表中删除一条记录时,该记录的所有选课记录也将被删除。
2(1)创建触发器sc_delete,当删除student表中的一条学生记录时,自动删除score表中对应学生的选课记录。 (2) 删除student表中的一条学生记录,验证触发器的作用。
1. 创建触发器:
```sql
CREATE TRIGGER sc_delete
AFTER DELETE ON student
FOR EACH ROW
BEGIN
DELETE FROM score WHERE student_id = OLD.student_id;
END;
```
2. 删除student表中的一条学生记录:
```sql
DELETE FROM student WHERE student_id = 1;
```
执行这个语句后,触发器会自动删除score表中对应学生的选课记录。可以通过以下语句验证:
```sql
SELECT * FROM score WHERE student_id = 1;
```
如果没有返回任何结果,说明触发器生效了,score表中对应学生的选课记录已被删除。
阅读全文