[解決済み] 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 にはあまり詳細が書かれていないので、正確なセマンティクスは実装で定義するとして、これはデータベースに応じて最適化するためのものだと思われます。
関連
-
[解決済み] Pythonには文字列の'contains'サブストリングメソッドがありますか?
-
[解決済み] Pythonで現在時刻を取得する方法
-
[解決済み] Pythonで2つのリストを連結する方法は?
-
[解決済み] ファイルのコピー方法について教えてください。
-
[解決済み] Pythonで例外を手動で発生(スロー)させる
-
[解決済み】ネストされたディレクトリを安全に作成するには?
-
[解決済み】Pythonに三項条件演算子はありますか?
-
[解決済み] Python 2.7サポート終了?
-
[解決済み] 古いバージョンのPythonにおける辞書のキーの並び順
-
[解決済み] PyMongoで.sortを使用する
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] Python 3.3のyield from構文は、実際にはどのような用途に使われるのでしょうか。
-
[解決済み] Pandasの'Freq'タグにはどのような値が有効ですか?
-
[解決済み] 文字列から先頭と末尾のスペースを削除するには?
-
[解決済み] スペースがないテキストを単語のリストに分割する方法
-
[解決済み] Django 1.7で初期マイグレーションからマイグレートバックする方法は?
-
[解決済み] 異なる順序で同じ要素を持つ2つのJSONオブジェクトを等しく比較するには?
-
[解決済み] Python Logging でログメッセージが2回表示される件
-
[解決済み] virtualenv の `--no-site-packages` オプションを元に戻す。
-
[解決済み] Python Empty Generator 関数
-
[解決済み] djangoのQueryDictをPythonのDictに変更するには?