2021-07-25 刷题41、42、43题

SQL41 构造一个触发器audit_log



SQL 41 题目

解答:

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对应的记录。



SQL 42 题目


SQL 42 题目

解答:

题目描述:删除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



SQL 43 题目


SQL 43 题目

解答:

UPDATE titles_test

SET to_date = NULL, from_date = '2001-01-01'

WHERE to_date = '9999-01-01'

表更新语句结构:

  UPDATE 表名

  SET 字段=值

  WHERE 过滤条件

你可能感兴趣的:(2021-07-25 刷题41、42、43题)