使用多个SQL Statments更新数据库

Rao*_*Rao 8 python mysql database-connection mysql-python

我正在使用从MySQL站点下载的mysql connector.Python 1.0.9.

这里有一个样本

DROP TABLE IF EXISTS my_table; 
CREATE TABLE my_table
(id INT NOT NULL AUTO_INCREMENT UNIQUE,
Shot VARCHAR(4),
sec varchar(5),
lay VARCHAR(15) NOT NULL,
lay_status VARCHAR(15) NOT NULL,
blk VARCHAR(10) NOT NULL,
blk_status VARCHAR(15) NOT NULL,
pri VARCHAR(10) NOT NULL,
pri_status VARCHAR(15) NOT NULL,
ani VARCHAR(10) NOT NULL,
ani_status VARCHAR(15) NOT NULL,
status VARCHAR(5)
);

INSERT INTO my_table VALUES
(1,'SH01','3','1863','yes','1863','yes','P4645','yes','P4557','yes','Over'),
(2,'SH02','2.5','1863','yes','P4645','no','P4557','yes','1863','no','Over'),
(3,'SH03','0.5','P4645','yes','P4557','yes','1863','yes','1863','yes','WIP'),
(4,'SH04','1.25','1863','no','P4645','no','P4557','yes','1863','yes','RTK'),
(5,'SH05','1','1863','yes','1863','yes','P4645','yes','P4557','yes','WIP'),
(6,'SH06','6','P4557','yes','P4645','yes','P4645','yes','P4557','yes','WIP');
Run Code Online (Sandbox Code Playgroud)

我能够执行如下的单个SQL语句.

import mysql.connector

cnx = mysql.connector.connect(user='scott', database='test')
cursor = cnx.cursor()

SQL = '''
        update my_table 
        set 
        LAY = 'P6682'
        , BLK = 'P6682'
        , ANI = 'P6682'
        where
        Shot = 'SH01';
      '''

cursor.execute(SQL)
Run Code Online (Sandbox Code Playgroud)

一切都很好,数据库正确更新.

现在,当我尝试使用多个语句更新数据库时,如下所示

import mysql.connector

cnx = mysql.connector.connect(user='scott', database='test')
cursor = cnx.cursor()

SQL = '''
    update my_table 
    set 
    LAY = 'P6682'
    , BLK = 'P6682'
    , ANI = 'P6682'
    where
    Shot = 'SH01';

    update my_table 
    set 
    LAY = '1863'
    , BLK = '1863'
    , ANI = '1863'
    where
    Shot = 'SH02'
'''

cursor.execute(SQL)
cnx.commit()
cur.close()
cnx.close()
cnx.disconnect()
Run Code Online (Sandbox Code Playgroud)

我得到了追踪错误

Traceback (most recent call last):
  File "Test_Module.py", line 24, in 
  File "C:\Python26\Lib\site-packages\mysql\connector\cursor.py", line 396, in execute
    "Use multi=True when executing multiple statements")
InterfaceError: Use multi=True when executing multiple statements
Run Code Online (Sandbox Code Playgroud)

我更新我的命令如下

cursor.execute(SQL,multi = True)

cnx.commit()
cur.close()
cnx.close()
cnx.disconnect()
Run Code Online (Sandbox Code Playgroud)

现在我没有得到任何错误/回溯.但是数据库没有得到更新.

任何人都能告诉我我在哪里做错了.

Rao*_*Rao 26

在对文档和帮助进行了长时间的研究之后.我能够解决这个问题.

使用for循环at cursor.executewith multi=Trueworking.我不知道为什么我们需要循环.

for result in cursor.execute(SQL, multi=True):
    pass
Run Code Online (Sandbox Code Playgroud)

没有循环只是cursor.execute(SQL, multi=True)没有在数据库中做任何更改.

import mysql.connector

cnx = mysql.connector.connect(user='scott', database='test')
cursor = cnx.cursor()

SQL = '''
    update my_table 
    set 
    LAY = 'P6682'
    , BLK = 'P6682'
    , ANI = 'P6682'
    where
    Shot = 'SH01';

    update my_table 
    set 
    LAY = '1863'
    , BLK = '1863'
    , ANI = '1863'
    where
    Shot = 'SH02'
'''

for result in cursor.execute(SQL, multi=True):
    pass

cnx.commit()
cur.close()
cnx.close()
cnx.disconnect()
Run Code Online (Sandbox Code Playgroud)

  • 谢谢!我花了几个小时试图弄清楚为什么这不起作用. (3认同)
  • 如果 mysql.connector 大师能够_解释_为什么需要 for 循环,那就太好了。 (2认同)