首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >pymysql批量取数

pymysql批量取数
EN

Stack Overflow用户
提问于 2018-08-23 07:58:34
回答 1查看 437关注 0票数 0

我正在使用pymysql与sql数据库进行交互,代码如下:

代码语言:javascript
复制
    query = "SELECT * FROM my_table"
    c = db.cursor(pymysql.cursors.DictCursor)
    c.execute(query)
    c.fetchall()

现在,我对一个包含3000个enteries的数据库执行此操作,这并不是很多,我计划在包含1500万个enteries的数据库上使用此方法,并希望将数据作为包含5000个enteries的批处理进行循环

我想知道我是否需要在查询中使用LIMIT和OFFSET来做到这一点,或者我可以只使用pymysql模块中的方法来做到这一点……谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-04-04 19:08:11

我这样做,是这样的:

代码语言:javascript
复制
query = "SELECT * FROM my_table"
c = db.cursor(pymysql.cursors.DictCursor)
c.execute(query)

limit = 5000
not_done = True

while not_done:
    data = []
    for _ in range(limit):
        try:
            data += [c.fetchone()]
        except:
            not_done = False
            break
    do_something_with_data()
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51976669

复制
相关文章

相似问题

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