注册 登录  
 加关注
查看详情
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

^_^ china.ygw的博客

软件开发/c/c++/数据库/开源/linux/windows/安全/网络...

 
 
 

日志

 
 
 
 

mysql的LOAD DATA INFILE IGNORE失效BUG  

2011-12-12 20:52:41|  分类: mysql |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

        前一段时间在使用mysq的5.5.9版本l时,遇到了一个load data infile ignore失效的问题。环境如下:

               drop table if exists test;
               create table test(
                      id int unsigned primary key,
                      state int,
                      name varchar(32) not null default ''
               );

 

               drop table if exists test_history;
               create table test_history(
                      seq int unsigned primary key auto_increment,
                      id int unsigned,
                      state int,
                      name varchar(32) not null default ''
                );

 

                drop trigger if exists trigger_1;
                delimiter //
                create trigger trigger_1 before update on test for each row
                begin
                       if OLD.state != NEW.state then
                             insert into test_history(id, state, name) values(NEW.id, NEW.state, NEW.name);
                       end if;
                end;//
                delimiter ;

 

                drop trigger if exists trigger_2;
                delimiter //
                create trigger trigger_2 before insert on test for each row
                begin
                       insert into test_history(id, state, name) values(NEW.id, NEW.state, NEW.name);
                end;//
                delimiter ;

 

                insert into test values(1, 1, 'test1');

                 select * from test into outfile 'c:\\test.sql';

                 load data infile 'c:\\test.sql' ignore into table test;

       test与test_history为测试数据表,其中test为当前最新数据表,test_history为历史数据表。当最新记录的state字段有变化时则记录一条历史记录。

       一开始先往test数据表插入一条记录,此时依据insert触发器,test_history数据表也有了一条记录。然后使用select into outfile语句把test数据表内容写入文件test.sql,然后使用load data infile语句再进行记录的导入,注意语句中增加了ignore关键字,但是遗憾的是,test_history表的记录在不断增加。

        在最新的5.5.19版本上测试还是存在该问题。

  评论这张
 
阅读(1018)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018