MySQL存储过程中的sql_mode问题
来源:站长家园 时间:2011-01-04 19:50:00
在my.cnf中设置了sql_mode='STRICT_TRANS_TABLES';
却发现还是有非法数据的写入,比如无符号整数字段本来值是0,还可以减,结果当然溢出了,经检查发现存储过程中默认的sql_mode并没有使用global的sql_mode,测试如下:
CREATE PROCEDURE p_test()
BEGIN
select @@session.sql_mode,@@global.sql_mode;
END;
call p_test();
+--------------------+---------------------+
| @@session.sql_mode | @@global.sql_mode |
+--------------------+---------------------+
| | STRICT_TRANS_TABLES |
+--------------------+---------------------+
1 row in set (0.00 sec)
CREATE PROCEDURE p_test1()
BEGIN
set sql_mode=@@global.sql_mode;
select @@session.sql_mode,@@global.sql_mode;
END;
call p_test1();
+---------------------+---------------------+
| @@session.sql_mode | @@global.sql_mode |
+---------------------+---------------------+
| STRICT_TRANS_TABLES | STRICT_TRANS_TABLES |
+---------------------+---------------------+
1 row in set (0.00 sec)


猜你喜欢
数字人组件反写[asp组件开发实例4]
教你在MySQL 5.0以上版本中配置主从库
960 Grid System 基本原理及使用方法
MySQL数据库的23个特别注意事项
JS+ASP实现无刷新新闻列表之分页
设计从"心"开始

使用access数据库时可能用到的数据转换
不唐突的JavaScript的七条准则[翻译]
JavaScript 实现 Konami Code

讲解数据库管理系统必须提供的基本服务
关于数据库的alter table操作和索引概念
如何使用表单发送电子邮件?
ASP判断E-Mail的合法性,以及过滤邮箱字符
MySQL Explain命令用于查看执行效果
ASP在线生成电话图片程序

form表单的submit方法和submit事件
带你深入了解Access数据库的4种安全方式
asp如何实现人民币的大写转换?
发一个数字拼图网页游戏
Linux安装卸载Mysql数据库
