zoukankan      html  css  js  c++  java
  • 不好的MySQL过程编写习惯

        刚才为了测试一个东西,写了个存储过程:  

        

    delimiter $$
    
    drop procedure if exists sp_test$$
    
    create procedure sp_test()
    begin
      declare v_cnt int;
      set v_cnt = 0;
      while v_cnt < 100000
      do
        insert into t1 select v_cnt, v_cnt+1, v_cnt+2, v_cnt+3;
        set v_cnt = v_cnt + 1;
      end while; 
    end $$
    
    delimiter ;

         很简单的一个过程,想要给表里插入10万条数据而已,但是实际执行过程中发现耗时很长,五分钟过去了还是没有执行完毕,于是我就把过程停掉了。又看了一遍过程我发现自己犯了一个曾经反复和别人强调过的错误,这种插入数据的过程,一定不要在循环中提交事务。MySQL默认是自动提交事务的,这一点众所周知,于是我的过程里每一条插入结束后都会自动将数据提交,于是每次提交都会写一次redo,于是我这个要写10万次redo,这个开销实在是很大很大的,于是我将过程做了简单的修改:

         

    delimiter $$
    
    drop procedure if exists sp_test$$
    
    create procedure sp_test()
    begin
      declare v_cnt int;
      set v_cnt = 0;
      start transaction;
      while v_cnt < 100000
      do
        insert into t1 select v_cnt, v_cnt+1, v_cnt+2, v_cnt+3;
        set v_cnt = v_cnt + 1;
      end while; 
      commit;
    end $$
    
    delimiter ;

         

         效果非常好。顺便说一句,头一次写的那个过程还有一个问题,比如说我刚才不耐烦的将terminal关掉了,但是我根本不知道我关掉的时候过程执行到哪里去了,比如我们有时候执行的时候发生了什么不可预知的错误,那么我们也就不知道现在执行到什么位置了。因此不要在循环中自动提交事务,要显式的开启事务。

  • 相关阅读:
    如何将程序集(dll)安装到全局程序集缓存(GAC)中
    当 ftp 遇上 http Proxy
    sql server 2008 帶主鍵table 字段 數據類型修改
    SQL 按指定顺序进行排序
    当发布时报错: 找不到 obj\Debug\Package\PackageTmp\xxx.aspx 文件
    c# 简体 繁体 转换
    SQL SERVER 简体与繁体 定序 轉換
    匿名类型与Lambda表达式
    使用委托实现了在循环中调用不同的方法
    学习源代码的心得
  • 原文地址:https://www.cnblogs.com/wingsless/p/5041838.html
Copyright © 2011-2022 走看看