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存储引擎类型较好;

  • 相关阅读:
    从dotNet到VB6之模仿构造OleDbDataAdapter与dataset结合
    编程的偷懒艺术与美感
    给您参考,现在开发数据库项目用.net 2005成熟吗?还是用.net2003比较有保证
    access数据库版权及容量问题
    中天股票数据格式
    受伤与药油的最佳搭配
    关于发布各种股票软件数据格式
    .net 与flash8传递(互传)数组的技巧
    我的C语言合集
    ZOJ 1205 Martian Addition 解题报告
  • 原文地址:https://www.cnblogs.com/-lpf/p/4793897.html
Copyright © 2011-2022 走看看