当前位置:  开发笔记 > 编程语言 > 正文

Python:cursor.execute影响的行数("SELECT ...")

如何解决《Python:cursor.execute影响的行数("SELECT")》经验,为你挑选了4个好方法。

如何访问受以下因素影响的行数:

cursor.execute("SELECT COUNT(*) from result where server_state='2' AND name LIKE '"+digest+"_"+charset+"_%'")

AndiDog.. 88

从PEP 249开始,通常由Python数据库API实现:

游标对象应响应以下方法和属性:

[...]

.rowcount
此只读属性指定最后一个.execute*()生成的行数(对于像'select'这样的DQL语句)或受影响的行(对于像'update'或'insert'这样的DML语句).

但要小心 - 它继续说:

如果未.execute*()对游标执行任何操作,则该属性为-1,或者无法通过接口确定最后一个操作的rowcount.[7]

注意:
DB API规范的未来版本可以重新定义后一种情况,使对象返回None而不是-1.

因此,如果您已经执行了您的语句,并且它可以运行,并且您确定您的代码将始终针对相同DBMS的相同版本运行,那么这是一个合理的解决方案.



1> AndiDog..:

从PEP 249开始,通常由Python数据库API实现:

游标对象应响应以下方法和属性:

[...]

.rowcount
此只读属性指定最后一个.execute*()生成的行数(对于像'select'这样的DQL语句)或受影响的行(对于像'update'或'insert'这样的DML语句).

但要小心 - 它继续说:

如果未.execute*()对游标执行任何操作,则该属性为-1,或者无法通过接口确定最后一个操作的rowcount.[7]

注意:
DB API规范的未来版本可以重新定义后一种情况,使对象返回None而不是-1.

因此,如果您已经执行了您的语句,并且它可以运行,并且您确定您的代码将始终针对相同DBMS的相同版本运行,那么这是一个合理的解决方案.


SQLite*always*为`SELECT`语句生成`cursor.rowcount == -1`,因为它不知道在你返回所有行之前将返回多少行; 这是SQLite的迭代器.
@ Tie-fighter:生成了一行,包含值`COUNT(*)`.例如,如果查询`SELECT name FROM result WHERE server_state ='2'`,您将获得零行,一行或多行.
我通过Connector/Python发现@MartijnPieters注释对于MariaDB是正确的.对于SELECT语句,我总是返回-1.
.rowcount for Select似乎始终为1

2> unutbu..:

尝试使用fetchone:

cursor.execute("SELECT COUNT(*) from result where server_state='2' AND name LIKE '"+digest+"_"+charset+"_%'")
result=cursor.fetchone()

result将持有一个元素的元组,值为COUNT(*).所以要查找行数:

number_of_rows=result[0]

或者,如果你宁愿一下子做到这一点:

cursor.execute("SELECT COUNT(*) from result where server_state='2' AND name LIKE '"+digest+"_"+charset+"_%'")
(number_of_rows,)=cursor.fetchone()

PS.尽可能使用参数化参数也是一种好习惯,因为它可以在需要时自动为您引用参数,并防止sql注入.

参数化参数的正确语法取决于您的python /数据库适配器(例如mysqldb,psycopg2或sqlite3).它看起来像

cursor.execute("SELECT COUNT(*) from result where server_state= %s AND name LIKE %s",[2,digest+"_"+charset+"_%"])
(number_of_rows,)=cursor.fetchone()



3> Boaz..:

受影响的行数从execute返回:

rows_affected=cursor.execute("SELECT ... ")

当然,正如AndiDog已经提到的,您可以通过随时访问游标的rowcount属性来获取行计数以获取上次执行的计数:

cursor.execute("SELECT ... ")
rows_affected=cursor.rowcount

从python MySQLdb的内联文档:

 def execute(self, query, args=None):

    """Execute a query.

    query -- string, query to execute on server
    args -- optional sequence or mapping, parameters to use with query.

    Note: If args is a sequence, then %s must be used as the
    parameter placeholder in the query. If a mapping is used,
    %(key)s must be used as the placeholder.

    Returns long integer rows affected, if any

    """


根据已经提到的[PEP 249](http://www.python.org/dev/peps/pep-0249/),不再定义`cursor.execute`方法返回的值(在之前版本的规范它应该像Boaz的例子一样工作.规范明确建议使用_更灵活的.rowcount属性,而不是`execute`方法返回的值是数据库接口实现依赖.
+1 Boaz,"rows_affected = cursor.rowcount"绝对是最好的答案.它不需要额外的查询,因为值始终存在.rowcount对于确定通过查询插入,更新,删除或检索的记录数非常有用.

4> 小智..:

在我看来,获取所选行数量的最简单方法如下:

当使用fetch命令(fetchall(),fetchone(),fetchmany())时,游标对象返回一个包含结果的列表.要获取所选行,只需打印此列表的长度.但它对fetchall()有意义.;-)

例:

print len(cursor.fetchall) 


使用len()有性能差异吗?
不要忘记之后的游标为空。
您从未在此处调用`cursor.fetchall`,因此文字代码如所写会产生类型错误。以及为什么要提取所有行“仅在列表上使用len()” **?那只是浪费资源。使用`SELECT COUNT(*)`让服务器进行计数。
推荐阅读
爱唱歌的郭少文_
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有