zoukankan      html  css  js  c++  java
  • MySQL不支持事务处理的解决方法

     

    MySQL数据库默认的存储引擎类型是MyISAM,这种存储引擎类型不支持事务处理。

    在MySQL中,只有InnoDB存储引擎类型的数据表才能支持事务处理。

    因此,如果想让MySQL支持事务处理,只要将数据表修改为InnoDB存储引擎类型即可。操作步骤如下:

    1. 进入到phpMyAdmin主界面,在导航面板中选择要转换为InnoDB存储引擎类型的数据库,例如选择db_xuesheng数据库。如下图所示:

    在phpMyAdmin中选择数据库

    2. 在主界面顶端点击“SQL”超链接,打开“在数据库db_xuesheng运行SQL查询”窗口。如下图所示:

    “在数据库db_xuesheng运行SQL查询”窗口

    3. 在窗口中输入

    show engines;

    SQL命令。

    4. 在窗口的右下角点击“执行”按钮,打开“显示查询框”页面。如下图所示:

    “显示查询框”页面

    5. 在“显示查询框”页面中,我们发现,InnoDB类型的Transactions项为YES,这说明InnoDB类型的数据库或数据表支持事务处理。

    下面,我们只要将相关的数据表修改为InnoDB存储引擎类型,就能支持事务处理操作了。

    6. 在phpMyAdmin的导航面板中选择要修改存储引擎类型的数据库db_xuesheng,然后在主界面顶端点击“SQL”超链接,打开“在数据库db_xuesheng运行SQL查询”窗口。如下图所示:

    “在数据库db_xuesheng运行SQL查询”窗口

    7. 在查询窗口中输入

    ALTER TABLE tb_chengji ENGINE = InnoDB;

    SQL命令。

    如果输入

    ALTER TABLE `tb_chengji` ENGINE = InnoDB;

    SQL命令也行。

    `tb_chengji`两边的符号是在英文输入的情况下,按下该键打出来的:

    特殊符号的输入

    8. 点击右下角的“执行”按钮,仍然打开“SQL”超链接窗口。如下图所示:

    打开“SQL”超链接窗口

    9. 至此,成功将数据表由MyISAM存储引擎类型转换为InnoDB存储引擎类型。

    我们也可以在数据表中执行事务处理操作了!

    //个人理解

    1:由于MyISAM存储引擎类型不支持事务,所以该类型一般都是系统表或者是日志表,

    2:如果表需要频繁的写操作,修改为InnoDB存储引擎类型较好;

  • 相关阅读:
    20165310_Exp2实验二《Java面向对象程序设计》
    20165310java_teamExp1_week1
    20165310java_blog_week7
    20165310java_blog_week6
    20165310 java_blog_week5
    20165211 获奖感想及java课程总结
    实验四 Android程序设计
    实验三 敏捷开发与XP实践
    第十周课下作业(补做)
    课下作业(补做)
  • 原文地址:https://www.cnblogs.com/-lpf/p/4793897.html
Copyright © 2011-2022 走看看