首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在PYPYODBC中使用executemany()

在PYPYODBC中使用executemany()
EN

Stack Overflow用户
提问于 2019-08-25 13:48:16
回答 1查看 3.4K关注 0票数 0

我的项目目前正在使用pypyodbc Python库连接到DB2数据库,我的源是MS,我需要从中读取数据并将数据加载到DB2表中。数据量为百万行,我试图使用executemany()方法在一次执行中加载50条记录,但我始终得到错误:

数据必须在列表、元组或行中。

我确实使用了list函数来键入游标结果,但它仍然不起作用。结果集中的数据采用[(record1),(record2)]格式。代码片段如下所示:

也尝试过键入sql结果集元组。

代码语言:javascript
复制
# use pypyodbc to establish a connection - db2_conn. 
cur = db2_conn.cursor()
cur.execute('...a query with 10 columns...')
result = cur.fetchmany(50)

insert_query = 'insert into db2_table (col1,col2,col3,...) values (?,?,?,..)'
cur.executemany(insert_query, list(result))
cur.commit()
EN

回答 1

Stack Overflow用户

发布于 2020-01-01 07:20:49

代码看起来没问题我以Db2作为源和目标测试了以下内容:

  1. 创建的源表和目标表
代码语言:javascript
复制
db2 "create table odbc_test(c1 int, c2 varchar(10))"
db2 "create table odbc_test_sorurce(c1 int, c2 varchar(10))"
  1. 用数据填充
代码语言:javascript
复制
db2 "insert into odbc_test_sorurce 
    with
       cte(c1)
    as
       (select
            1
        from
           sysibm.sysdummy1
        union all
        select
           c1 + 1
        from
           cte
        where c1 < 1000) select  c1, 'row' || c1 from cte"
  1. 连接到数据库并获取行。
代码语言:javascript
复制
import pyodbc
cnx = pyodbc.connect("DRIVER={DB2};HOSTNAME=localhost;DATABASE=sample;UID=xxxx;PWD=xxxxx;PROTOCOL=TCPIP;PORT=60115")
cnx.autocommit = False
cur = cnx.cursor()
cur.execute('select c1, c2 from odbc_test_sorurce')
result = cur.fetchmany(50)
  1. 这给了我一个结果清单:
代码语言:javascript
复制
In [16]: result
Out[16]: 
[(1, 'row1'),
 (2, 'row2'),
 (3, 'row3'),
 (4, 'row4'),
 (5, 'row5'),
 (6, 'row6'),
 (7, 'row7'),
...


In [17]: type(result)
Out[17]: list
  1. 插入的效果很好:
代码语言:javascript
复制
cur.executemany("insert into odbc_test(c1, c2) values (?,?)", result)
cnx.commit()
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57646596

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档