1. ホーム
  2. python

[解決済み] Python db-api: fetchone vs fetchmany vs fetchall

2023-08-20 17:20:11

質問

今日、同僚とpythonのdb-apiのfetchoneとfetchmanyとfetchallについて議論したところです。

これらのそれぞれのユースケースは、使っているdb-apiの実装に依存すると思いますが、一般的にfetchone vs fetchmany vs fetchallのユースケースはどのようなものなのでしょうか?

言い換えれば、以下のものは同等なのでしょうか? それとも、これらのうちどれかが他よりも好ましいのでしょうか? もしそうなら、どのような状況でそうなるのでしょうか?

cursor.execute("SELECT id, name FROM `table`")
for i in xrange(cursor.rowcount):
    id, name = cursor.fetchone()
    print id, name


cursor.execute("SELECT id, name FROM `table`")
result = cursor.fetchmany()
while result:
    for id, name in result:
        print id, name
    result = cursor.fetchmany()


cursor.execute("SELECT id, name FROM `table`")
for id, name in cursor.fetchall():
    print id, name

どのように解決するのですか?

確かに実装に依存すると思いますが、MySQLdbのソースを見れば違いの見当がつくと思います。オプションによりますが、mysqldb fetch* は現在の行のセットをメモリに保持するか、サーバサイドに保持します。したがって fetchmany vs fetchone は、(python の)メモリに何を保持するか、db サーバサイドに何を保持するかという柔軟性をここに持っています。

PEP 249 にはあまり詳細が書かれていないので、正確なセマンティクスは実装で定義するとして、これはデータベースに応じて最適化するためのものだと思われます。