Python中文
首页
教程
问答
标签
搜索
登录
注册
函数需要太多时间来处理来自数据库的循环(3000次)
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我在3000次循环中调用一个函数。我正在调用该函数并从该函数中获取一些字典,但这需要时间。我正在从数据库中获取数据,这给了我大约3000行,我正在循环这些行,并在那个循环中调用函数,从数据库中获取数据并返回字典,但这需要时间。你知道吗</p> <p><strong>代码:</strong></p> <pre><code>def test(request, uni_id): try: Obj = get_object_or_404(tabl_name, id=uni_id) except: Obj = None dict = {} if Obj:outlet_info dict['data1'] = Obj.id dict['data2'] = Obj.name dict['data3'] = Obj.eg dict['data4'] = Obj.access return dict cursor.execute('''SELECT cd.name, cd.no,ofk.demo_id FROM `main_table` as myo LEFT JOIN `table1` as emt ON emt.some_id = myo.some1_id LEFT JOIN `table2` as ofk ON ofk.id = myo.kit_id LEFT JOIN `table3` as cd ON cd.eg_id = myo.eg_id WHERE emt.type='test'''' result = dictfetchall(cursor) tmp_list, tmp_dict = [], {} for res in result: tmp_dict['name'] = res['name'] tmp_dict['no'] = res['no'] info = test(request,res['demo_id']) tmp_dict['data1'] = info['data1'] tmp_list.append(tmp_dict.copy()) </code></pre> <p>在这里,我从查询中获取<code>demo_id</code>,并使用函数<code>test</code>将其传递给另一个查询以获取数据,因此需要花费太多时间。你知道吗</p> <p>有人能告诉我如何提高速度或将<code>demo_id</code>包含到主查询并从主查询获取数据吗?你知道吗</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>您正在进行3000 db的调用(通过调用<code>get_object_or_404</code>3k次),这肯定会减慢速度。相反,您应该尝试通过<code>tablemanager.filter(id__in=id_list)</code>获取对象。在循环中准备id\u列表并将该列表传递给测试函数。你知道吗</p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
尽管Python中的所有内容都是引用,为什么Python导师在没有指针的列表中绘制字符串和整数?
7 回答
尽管python中的表达式为false,但循环仍在运行
10 回答
尽管python代码正确,但从nifi ExecuteScript处理器获取语法错误
9 回答
尽管Python在Neovim中工作得很好,但插件不能识别Neovim中的Python主机
4 回答
尽管python字典包含了大量的条目,但它并没有增长
7 回答
尽管python说模块存在,为什么我会得到这个消息?
6 回答
尽管setuptools和控制盘是最新的,但无法识别singleversionexternallymanaged
3 回答
尽管stdout和stderr重定向,但未捕获错误消息
8 回答
尽管Tensorboard的事件太大,但Tensorboard的步骤太少了
5 回答
尽管tkinter上的变量已更改,但显示未更改
5 回答
尽管try/except使用Python进行单元测试时出现断言错误
2 回答
尽管URL是sam,但仍会抛出“达到最大重定向”
4 回答
尽管url有效,Pandas仍读取url的\u csv错误
10 回答
尽管while中存在时间延迟,但LINUX线程的CPU利用率为100%(1)
1 回答
尽管x0在范围内,Scipy优化仍会引发ValueError
10 回答
尽管xpath正确,但使用selenium单击链接仍不起作用
10 回答
尽管下载了ffmpeg并设置了路径变量python,但没有后端错误
10 回答
尽管下载了i,但找不到型号“fr”
10 回答
尽管下载了plotnine包,但未获取名为“plotnine”的模块时出错
4 回答
尽管为所有行指定了权重,网格(0)仍不起作用
5 回答