免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2498 | 回复: 9
打印 上一主题 下一主题

重复定义为哪般? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-01-15 21:20 |只看该作者 |倒序浏览
cursor = mysql_cursor()
cursor.execute ("""
SELECT sha
    FROM hashes
&nbsp;&nbsp;&nbsp;&nbsp;WHERE runs>=0 AND runs<100 AND s+l>=1 AND state="
M"
&nbsp;&nbsp;&nbsp;&nbsp;ORDER BY runs, date DESC, s+l DESC, s DESC
&nbsp;&nbsp;&nbsp;&nbsp;LIMIT %d;
"
"" % (len(ut_que) * n_max))
all_rows = cursor.fetchall()

# copy hashes to ut dir
cursor = mysql_cursor()



以上代码为大师所写,我有点看不懂
cursor = mysql_cursor()
后为啥又定义一次?
cursor = mysql_cursor()

论坛徽章:
0
2 [报告]
发表于 2010-01-15 21:24 |只看该作者
mysql_cursor() 的代码是?

论坛徽章:
0
3 [报告]
发表于 2010-01-15 21:31 |只看该作者
更正下

楼上问的答案



def mysql_cursor():
&nbsp;&nbsp;&nbsp;&nbsp;global _conn
&nbsp;&nbsp;&nbsp;&nbsp;global _curs
&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;if not _conn:   # new connection on need
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;_conn = MySQLdb.connect (host = "localhost",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;user = "root",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;passwd = "Python123",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;db = "ebooks")
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;_curs = None
&nbsp;&nbsp;&nbsp;&nbsp;mysql_commit()              # save previous cursor
&nbsp;&nbsp;&nbsp;&nbsp;_curs = _conn.cursor()      # new cursor
&nbsp;&nbsp;&nbsp;&nbsp;return _curs


[ 本帖最后由 advancejar 于 2010-1-15 21:34 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2010-01-15 21:35 |只看该作者
代码在哪里看到的?

论坛徽章:
0
5 [报告]
发表于 2010-01-15 21:38 |只看该作者
某个python版主的代码,朋友转给我学习用

论坛徽章:
0
6 [报告]
发表于 2010-01-15 21:40 |只看该作者
mysql_commit()              # save previous cursor

这里又是怎么写的?

论坛徽章:
0
7 [报告]
发表于 2010-01-15 21:41 |只看该作者
你私底下也传给我学习学习吧

论坛徽章:
0
8 [报告]
发表于 2010-01-15 21:47 |只看该作者
看注释应该是将局部变量的 _curs保存起来,并生成新的cursor返回

为什么这样做就要看完整点的代码了

论坛徽章:
0
9 [报告]
发表于 2010-01-15 21:50 |只看该作者
1楼的代码石油把酒是线程内的代码
之所以这样写是不是因为同一个cursor不能被多个线程同时使用啊
瞎猜的没用过mysql的说

论坛徽章:
0
10 [报告]
发表于 2010-01-16 09:52 |只看该作者
原帖由 bleem1998 于 2010-1-15 21:50 发表
1楼的代码石油把酒是线程内的代码
之所以这样写是不是因为同一个cursor不能被多个线程同时使用啊
瞎猜的没用过mysql的说

恩,就是防止避免多线程。

其实无所谓,嘿嘿
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP