我有以下查询
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 中。如何插入多行?
最佳答案
我看到三个选项:
将每个查询分别发送到数据库:
[...] self.con.execute(query1) self.con.execute(query2) self.con.execute(query3) [...]
[已删除,因为它不适用于此处]
不过,我对这个
multi=True
不是很熟悉;可能存在重复调用self.con.nextset()
的解决方案。根据文档,这仅适用于多个结果集,但也许在多查询请求中也需要。
关于python - 如何向 MYSQL 插入多个值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15133401/