e股脑电脑教程网
  • 首 页
  • 操作系统
  • 应用软件
  • 下载工具
  • 影音视频
  • 办公软件
  • 媒体制作
  • 网站建设
  • 平面设计
  • 数据库
  • 程序开发
  • 视频教程
编辑推荐: | 文章搜索:
您现在的位置: e股脑 >> 数据库 >> MySQL教程 >> MySQL5新特点(触发器) >> 教程正文
 
教程搜索
 
 
相关教程
  • MySQL的管理工具:phpMyA
  • MySQL常用操作命令
  • 安装MySQL步骤详解
  • 从MySQL得到最大的性能
  • 通过C API远程连接Mysql 
  • MySQL5安装详细介绍
  • 如何在windows系统下安装
  • 在Linux/Unix平台下安装M
  • MySQL5数据库与管理相关的
  • MySQL的常见错误
  • 在MySQL数据库中执行SQL语
  • MySQL5新特点(视图)
  • MySQL5新特点(触发器)
  • 关于Mysql 4.1语言问题的
  • 运行多个MYSQL服务器
  • 让MYSQL有效地装载数据
 
 
赞 助 商
 
 
MySQL5新特点(触发器)
  • 来源:e股脑
  • 点击次数:
  • 更新时间:2008-2-4

  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;

  可见触发器功能可以提高管理人员管理数据库的灵活性。

  • 上一篇教程: 关于Mysql 4.1语言问题的完美解决方法
  • 下一篇教程: MySQL5新特点(视图)
  •  

    关于本站 | 广告联系 | 版权声明 | 使用帮助

    Copyright © 2004-2008 www.egunao.com All rights reserved.