ホームページ >バックエンド開発 >Python チュートリアル >Django モデルの効率を向上させるためのいくつかの小さな方法

Django モデルの効率を向上させるためのいくつかの小さな方法

高洛峰
高洛峰オリジナル
2016-10-17 14:03:401070ブラウズ

Django のモデルは、特に大量のデータベース操作を行う場合にはあまり効率的ではありません。企業の Web サイトを開く場合やプロジェクトをアウトソーシングする場合にのみ Django を使用する場合は、省略しても問題ありません。プログラムの効率要件が比較的高い場合は、次の方法に注意する必要があります。
1. count() メソッド:
count メソッドを使用してレコード数を取得したい場合は、次のメソッドを使用できます:
num = info.objects.filter('...').count()
見てみましょう Django モデルモジュールで count メソッドを記述する方法は?
def count(self):
"""
SELECT COUNT() を実行し、レコード数を
整数として返します。
QuerySet がすでに完全にキャッシュされている場合、これは単純にキャッシュされた結果セットの長さを返します
。複数の SELECT COUNT(*) 呼び出し。
"""
self._result_cache が None でなく、self._iter:
return len(self._result_cache)
return self.query.get_count(using=self.db)

の場合上記のことから、djang モデルの count() は、実際にデータベースにクエリを実行する SELECT COUNT() ステートメントを実行する必要があります。このように、レコード数が多い場合、データベースへのクエリの効率は比較的高くなります。 len() メソッドを使用して長さを見つける場合、使用される反復の効率は低くなります。
info = info.objects.filter('...')
num = len(info)
2 多用途のスライス
たとえば、データをクエリしたい場合、データ量が比較的大きい場合、必要な機能はありません。クエリの制限 たとえば、
ニュース データをページに表示したい場合、すべてのデータを読み取るのではなく、1 ページに表示したいだけのデータを読み取る必要があります。を一度に実行し、定義された条件に従ってデータを表示します。
たとえば、トップ 10 のニュース項目を表示したい場合は、次のように実行します:
news = News.objects.all()[1:10]
代わりに:
news = News.objects.all()
news = news[1:10]
なぜなら
news = News.objects.all()
news = news[1:10]
データベース内のすべてのデータを読み取ることになるため、あまり効率的ではありません。
上記のポイントは、Django モデルの効率を向上させるためのいくつかの小さな方法です。Django でプロジェクトを開発する際には、皆さんもいくつかの効率的な点に注意を払っていただければ幸いです。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。