加入收藏 | 设为首页 | 会员中心 | 我要投稿 东莞站长网 (https://www.0769zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

cursor.fetchall()使用MySQldb和python返回额外的字符

发布时间:2021-03-04 22:30:47 所属栏目:MySql教程 来源:网络整理
导读:当我使用python从SQL数据库中获取结果时,我会在返回值的开头和结尾处获得额外的章程.例如,下面的代码返回((56L,),而不是56,是否有人知道如何获得值以及((,)实际意味着什么? hp= 56id= 3database = MySQLdb.connect (host="localhost",user = "root",passwd

当我使用python从SQL数据库中获取结果时,我会在返回值的开头和结尾处获得额外的章程.例如,下面的代码返回((56L,),而不是56,是否有人知道如何获得值……以及((,)实际意味着什么……?

hp= 56
id= 3

database = MySQLdb.connect (host="localhost",user = "root",passwd = "",db = "db")

cursor = database.cursor()

cursor.execute("UPDATE period_option SET points =%s WHERE period_option_id =%s",(hp,id))

cursor.execute("SELECT points FROM period_option WHERE period_option_id =%s",(po_id_home))
results = cursor.fetchall()
print results  

谢谢! 最佳答案 fetchall()返回元组的列表(实际上是:元组).可以将其视为一系列行,其中每一行都是列中的一系列项.如果您确定您的搜索只返回1行,请使用fetchone(),它返回一个元组,这更容易解压缩.以下是从fetchall()和fetchone()中提取所需内容的示例:

# Use fetchall():
((points,) = cursor.fetchall()  # points = 56L

# Or,if you use fetchone():
(points,) = cursor.fetchone()     # points = 56L

(编辑:东莞站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读