python - 如何向 MYSQL 插入多个值?

标签 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 中。如何插入多行?

最佳答案

我看到三个选项:

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

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

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

关于python - 如何向 MYSQL 插入多个值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15133401/

相关文章:

python - Django 标签和翻译 - 模型设计

mysql - 是否可以在 mysql 中从表中选择不包含某些内容的列?

mysql - 查询获取带有子记录的父记录,然后是mysql中的下一个父子记录

php - 我可以使用 RedBean PHP ORM 导出 Sqlite 数据库并导入到 MySQL 吗?

mysql - 如何从 Ajax 调用或更改 SQL 查询中获取 "normalize"json 对象

python - spark - 将数据框转换为列表以提高性能

python - 使用 awk/sed/bash 切割 python 输出

javascript - django中刷新传单 map

python - 使用 Eclipse/Python 自定义突出显示?

php - 带有 Analytics 的页面计数器,其中数据存储在 MySQL 数据库中