解答:
create trigger audit_log
after insert on employees_test
foreach row
begin
insert into audit values(new.id,new.name);
end
在MySQL中,创建触发器语法如下:
CREATE TRIGGER trigger_name
trigger_time trigger_event ON tbl_name
FOR EACH ROW
trigger_stmt
其中:
trigger_name:标识触发器名称,用户自行指定;
trigger_time:标识触发时机,取值为 BEFORE 或 AFTER;
trigger_event:标识触发事件,取值为 INSERT、UPDATE 或 DELETE;
tbl_name:标识建立触发器的表名,即在哪张表上建立触发器;
trigger_stmt:触发器程序体,可以是一句SQL语句,或者用 BEGIN 和 END 包含的多条语句,每条语句结束要分号结尾。
【NEW 与 OLD 详解】
MySQL 中定义了 NEW 和 OLD,用来表示
触发器的所在表中,触发了触发器的那一行数据。
具体地:
在 INSERT 型触发器中,NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据;
在 UPDATE 型触发器中,OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据;
在 DELETE 型触发器中,OLD 用来表示将要或已经被删除的原数据;
使用方法: NEW.columnName (columnName 为相应数据表某一列名)
---不是很明白触发器的实际运用,原理解释的也有点难以理解,需要再次学习这个知识点---
SQL42 删除emp_no重复的记录,只保留最小的id对应的记录。
解答:
题目描述:删除emp_no重复的记录,只保留最小的id对应的记录。
个人思路:1.找出每个emp_no里对应的最小id。2.删除除1里记录的所有数据。
delete from titles_test
where id not in
(
select min(id)
from titles_test
group by emp_no
)
遭遇问题:you can't specify target table 'titles_test' for update in FROM clause
网查原因:在MYSQL里,不能先select一个表的记录,在按此条件进行更新和删除同一个表的记录,
解决办法:将select得到的结果,再通过中间表select一遍,这样就规避了错误,这个问题只出现于mysql,mssql和oracle不会出现此问题。
delete from titles_test
where id not in
(
select * from
(
select min(id)
from titles_test
group by emp_no
) as T1
)
SQL43 将所有to_date为9999-01-01的全部更新为NULL
解答:
UPDATE titles_test
SET to_date = NULL, from_date = '2001-01-01'
WHERE to_date = '9999-01-01'
表更新语句结构:
UPDATE 表名
SET 字段=值
WHERE 过滤条件