Conventions and Styles约定和编程风格
每次我想要演示实际代码时
![](/icons/46346dou.gif)
我会对mysql客户端
![](/icons/46346de.gif)
屏幕就出现
![](/icons/46346de.gif)
代码进行调整
![](/icons/46346dou.gif)
将字体改成Courier
![](/icons/46346dou.gif)
使他们看起来和普通文本不
![](/icons/46346yi.gif)
样(让大家区别
![](/icons/46346chengxu.gif)
代码和正文)
![](/icons/46346dou2.gif)
在这里举个例子:
mysql> DROP FUNCTION f;
Query OK, 0 rows affected (0.00 sec)
如果例子比较大
![](/icons/46346dou.gif)
则需要在某些行和段落间加注释
![](/icons/46346dou.gif)
同时我会用将"<--"符号放在页面
![](/icons/46346de.gif)
右边以表示强调
![](/icons/46346dou2.gif)
例如:
mysql> CREATE PROCEDURE p
-> BEGIN
-> /* This procedure does nothing */ <--
-> END;//
Query OK, 0 rows affected (0.00 sec)
有时候我会将例子中
![](/icons/46346de.gif)
"mysql>"和"->"这些系统显示去掉
![](/icons/46346dou.gif)
你可以直接将代码复制到mysql客户端
![](/icons/46346chengxu.gif)
中(如果你现在所读
![](/icons/46346de.gif)
不是电子版
![](/icons/46346de.gif)
![](/icons/46346dou.gif)
可以在mysql.com网站WebSite下载相关脚本)
所以
![](/icons/46346de.gif)
例子都已经在Suse 9.2 Linux、Mysql 5.0.3公共版上测试通过
![](/icons/46346dou2.gif)
在您阅读本书
![](/icons/46346de.gif)
时候
![](/icons/46346dou.gif)
Mysql已经有更高
![](/icons/46346de.gif)
版本
![](/icons/46346dou.gif)
同时能支持更多OS了
![](/icons/46346dou.gif)
包括Windows
![](/icons/46346dou.gif)
Sparc
![](/icons/46346dou.gif)
HP-UX
![](/icons/46346dou2.gif)
因此这里
![](/icons/46346de.gif)
例子将能正常
![](/icons/46346de.gif)
运行在您
![](/icons/46346de.gif)
电脑上
![](/icons/46346dou2.gif)
但如果运行仍然出现故障
![](/icons/46346dou.gif)
可以咨询你认识
![](/icons/46346de.gif)
资深Mysql用户
![](/icons/46346dou.gif)
这样就能得到比较好
![](/icons/46346de.gif)
支持和帮助
Why Triggers 为什么要用触发器
我们在MySQL 5.0中包含对触发器
![](/icons/46346de.gif)
支持是由于以下原因:
MySQL早期版本
![](/icons/46346de.gif)
用户长期有需要触发器
![](/icons/46346de.gif)
要求
我们曾经许诺支持所有ANSI标准
![](/icons/46346de.gif)
特性
您可以使用它来检查或预防坏
![](/icons/46346de.gif)
数据进入数据库
您可以改变或者取消INSERT, UPDATE以及DELETE语句
您可以在
![](/icons/46346yi.gif)
个会话中监视数据改变
![](/icons/46346de.gif)
动作
在这里我假定大家都读过"MySQL新特性"丛书
![](/icons/46346de.gif)
第
![](/icons/46346yi.gif)
集--"MySQL存储过程"
![](/icons/46346dou.gif)
那么大家都应该知道MySQL至此存储过程和
![](/icons/46346hanshu.gif)
![](/icons/46346dou.gif)
那是很重要
![](/icons/46346de.gif)
知识
![](/icons/46346dou.gif)
![](/icons/46346yinwei.gif)
在触发器中你可以使用在
![](/icons/46346hanshu.gif)
中使用
![](/icons/46346de.gif)
语句
![](/icons/46346dou2.gif)
特别举个例子:
复合语句(BEGIN / END)是合法
![](/icons/46346de.gif)
.
流控制(Flow-of-control)语句(IF, CASE, WHILE, LOOP, WHILE, REPEAT, LEAVE,ITERATE)也是合法
![](/icons/46346de.gif)
.
变量声明(DECLARE)以及指派(SET)是合法
![](/icons/46346de.gif)
.
允许条件声明.
异常处理声明也是允许
![](/icons/46346de.gif)
.
但是在这里要记住
![](/icons/46346hanshu.gif)
有受限条件:不能在
![](/icons/46346hanshu.gif)
中访问表.因此在
![](/icons/46346hanshu.gif)
中使用以下语句是非法
![](/icons/46346de.gif)
ALTER 'CACHE INDEX' CALL COMMIT CREATE DELETE
DROP 'FLUSH PRIVILEGES' GRANT INSERT KILL
LOCK OPTIMIZE REPAIR REPLACE REVOKE
ROLLBACK SAVEPOINT 'SELECT FROM table'
'SET system variable' 'SET TRANSACTION'
SHOW 'START TRANSACTION' TRUNCATE UPDATE
在触发器中也有完全
![](/icons/46346yi.gif)
样
![](/icons/46346de.gif)
限制.
触发器相对而言比较新
![](/icons/46346dou.gif)
因此会有(bugs)缺陷.所以我在这里给大家警告
![](/icons/46346dou.gif)
就像我在存储过程书中所说那样.不要在含有重要数据
![](/icons/46346de.gif)
数据库中使用这个触发器
![](/icons/46346dou.gif)
如果需要
![](/icons/46346de.gif)
话在
![](/icons/46346yi.gif)
些以测试为目
![](/icons/46346de.gif)
![](/icons/46346de.gif)
数据库上使用
![](/icons/46346dou.gif)
同时在你对表创建触发器时确认这些数据库是默认
![](/icons/46346de.gif)
延伸阅读
- 2010-12-15-- php基础教程,PHP 和 MySQL 基础教程(二)
- 2010-12-15-- php基础教程,PHP 和 MySQL 基础教程(一)
- 2010-12-15-- php基础教程,PHP 和 MySQL 基础教程(三)
- 2010-12-15-- php基础教程,PHP 和 MySQL 基础教程(四)
- 2011-3-11-- mysql,降低锁竞争 减少MySQL用户等待时间
- 2010-11-24-- mysql,升级 MySQL
- 2010-12-13-- mysql下载,mysql
- 2010-12-13-- mysql教程,MySQL Workbench的使用教程
- 2011-1-5-- mysql教程,MySQL教程学习笔记
- 2011-2-19-- mysql,清理Mysql
最新评论