MySQL5新特点(触发器)

2008-02-23 07:42:59来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

MySQL从5.0.2版开始引入触发器,触发器就是个已命名的数据库对象,这个对象和某张表 相关,而且当这张表发生某种特定事件后,触发器将被激活执行相应的动作,触发器允许这 些动作在这张表中的一行或多行的数据被操作的前后执行。在流行业务系统的处理过程中,研发和管理人员能够用触发器来实现数据审计和其他安全相关的功能,如在运行中的数据执行加密功能。

举个例子来说:一个客户数据库中包含客户的社会保险号,企业的安全和审计人员必须将这些信息加密后存入磁盘。针对这种情况,管理员能够通过创建一个触发器来自动获取并加密这些数据然后再插入相应的数据库表中。如下所示:
mysql> delimiter // 

mysql> create trigger t_customer_insert before insert on customer

    -> for each row

    -> begin 

    -> set NEW.customer_ssn = aes_encrypt(NEW.customer_ssn,'password');

    -> end; 

    -> //

Query OK, 0 rows affected (0.00 sec)

mysql> delimiter ;



mysql> insert into customer values (1,'fred','smith','456097234');

Query OK, 1 row affected (0.00 sec)

mysql> select * from customer;

结果显示如下图:



能够看出存在磁盘数据库表中的社会保险号ssn已变成加密后的不可读乱码格式。

另外MySQL5也引进了对游标的支持,在第一个发行版本中游标有向前翻阅结果集和不可执行数据更新语句的特点。游标能够用在MySQL5的新编码对象,如存储过程和触发器,甚至是单独的存储过程逻辑块中。以下是个在存储过程中的使用游标的简单例子:
mysql> delimiter // 

mysql> CREATE PROCEDURE cursor_demo()

    -> BEGIN 

    ->   DECLARE a, b CHAR(16); 

    ->   DECLARE cur1 CURSOR FOR SELECT id,data FROM test.t1;

    -> OPEN cur1; 

    -> REPEAT  

    ->  FETCH cur1 INTO a,b;

    -> UNDONE END REPEAT;

    -> CLOSE cur1; 

    -> END

    -> //

下面再举一个触发器的例子,该例子能够计算任何插入某表的某个列中的数值的和:
mysql> CREATE TABLE account (acct_num INT, amount DECIMAL(10,2));

mysql> CREATE TRIGGER ins_sum BEFORE INSERT ON account

    -> FOR EACH ROW SET @sum = @sum   NEW.amount;
可见触发器功能能够提高管理人员管理数据库的灵活性。

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: MySQL5新特点(视图)

下一篇: 修改MySQL的默认密码