如何向MYSQL插入多个值?

时间:2013-02-28 10:42:21

标签: python mysql

我有以下查询

INSERT INTO `min01_aggregated_data_800` (`datenum`,`Timestamp`,`QFlag_R6_WYaw`)  VALUES ('734970.002777778','2012-04-11 00:04:00.000','989898') ON DUPLICATE KEY UPDATE `datenum`=VALUES(`datenum`);
INSERT INTO `min01_aggregated_data_100` (`datenum`,`Timestamp`,`QFlag_R6_WYaw`)  VALUES ('734970.002777778','2012-04-11 00:04:00.000','989898') ON DUPLICATE KEY UPDATE `datenum`=VALUES(`datenum`);
INSERT INTO `min01_aggregated_data_300` (`datenum`,`Timestamp`,`QFlag_R6_WYaw`)  VALUES ('734970.002777778','2012-04-11 00:04:00.000','989898') ON DUPLICATE KEY UPDATE `datenum`=VALUES(`datenum`);

我正在使用mysql.connector包将数据插入MySQL

self.db = mysql.connector.Connect( host = self.m_host, user = self.m_user, password = self.m_passwd, \
        database = self.m_db, port = int( self.m_port ) )
self.con = self.db.cursor( cursor )

self.con.execute( query ) 
self.db.commit()  
self.db.close()
self.con.close()

但我收到以下错误Use multi=True when executing multiple statements

我试图在这种情况下使用multi=True我没有得到任何异常,但数据不会插入MySQL。如何插入多行?

2 个答案:

答案 0 :(得分:0)

我看到三个选项:

  1. 将每个查询分别发送到数据库:

    [...]
    self.con.execute(query1)
    self.con.execute(query2)
    self.con.execute(query3)
    [...]
    
  2. [删除,因为它不适用于此处]

  3. 然而,我对这个multi=True并不是很熟悉;有可能存在一个反复调用self.con.nextset()的解决方案。根据文档,这仅适用于多个结果集,但也许在多查询请求中也需要它。

答案 1 :(得分:0)

您有三个单独的查询,因此每个查询都应单独运行,即:

self.con.execute(query1)
self.con.execute(query2)
self.con.execute(query3)