zoukankan      html  css  js  c++  java
  • python对MySQL进行数据的插入、更新和删除之后需要commit,数据库才会真的有数据操作。(待日后更新)

      今天在尝试用下面的python代码对MySQL进行数据的插入、更新和删除时, 突然发现代码执行成功, 通过代码查询也显示数据已经插入或更新, 但是当我在MySQL客户端通过SQL语句查询时, 数据库中的数据一点变化都没有。 又反复实验了多次, 结果都是一样的。

     1 #!/usr/bin/python
     2 #Program:
     3 #   to get some information from mysql
     4 import MySQLdb as mdb
     5 import sys
     6 
     7 conn = mdb.connect(host = 'localhost', user = 'root', passwd = '8023xue0526', db = 'contact')
     8 
     9 cur = conn.cursor()
    10 cur.execute("insert into contact values('222221', 'ni')")
    11 cur.execute("select * from contact")
    12 row_num = int(cur.rowcount)
    13 for i in range(row_num):
    14     row = cur.fetchone()
    15     print row
    16 cur = conn.cursor()
    17 conn.close()

      通过在网上查找, 最终才有了一点眉目, 此问题与MySQL的存储引擎对事务的支持有关。 原来MySQL中有多种类型的存储引擎, 例如: MyISAM, InnoDB等。 MyISAM不支持事务处理, 而InnoDB是事务型数据库, 支持事务。  我的MySQL的默认存储引擎就是InnoDB, 所以对数据库数据的操作会在事先分配的缓存中进行, 只有在commit之后, 数据库的数据才会改变。 修改后的代码如下:

     1 #!/usr/bin/python
     2 #Program:
     3 #   to get some information from mysql
     4 import MySQLdb as mdb
     5 import sys
     6 
     7 conn = mdb.connect(host = 'localhost', user = 'root', passwd = '8023xue0526', db = 'contact')
     8 
     9 cur = conn.cursor()
    10 cur.execute("insert into contact values('222221', 'ni')")
    11 cur.execute("select * from contact")
    12 row_num = int(cur.rowcount)
    13 for i in range(row_num):
    14     row = cur.fetchone()
    15     print row
    16 #在数据操作完成之后,进行commit,完成数据库的数据更新
    17 conn.commit()
    18 cur = conn.cursor()
    19 conn.close()

      但是以前在用MySQL C API 对数据库进行数据操作的时候没有这情况, 通过查看资料, autocommit变量的状态决定是否每次对数据操作之后自动commit, 在MySQL客户端里autocommit=ON时, 在客户端输入SQL语句, 每次都会自动执行一次commit。 我查看了自己的MySQL的autocommit为ON,  但是还是没搞清楚为什么同在InnoDB存储引擎下, autocommit=ON, 用C API 无需commit, 而用Python API 必须commit。     看到此文章的网友如果知道, 多谢你能给我解惑。。

  • 相关阅读:
    kmp算法详解
    艾伦.席森.图灵
    gcd详解
    Shortest Prefixes 字典树模板
    Hat's Words 字典树变式
    统计难题 字典树模板
    Phone List 字典树模板
    字典树详解
    Basic Gcd Problem 线性筛
    codeforces 454 D. Little Pony and Harmony Chest(状压dp)
  • 原文地址:https://www.cnblogs.com/KarryWang/p/3225551.html
Copyright © 2011-2022 走看看