質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

2回答

587閲覧

Webアプリ開発におけるSQLの数の目安

takaocs

総合スコア57

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

2クリップ

投稿2020/07/16 00:54

Djangoを使ってWebアプリの開発を行っています。
その際、「django-debug-toolbar」というライブラリを使用しています。
このライブラリを使用すると、ページを表示する際に実行されたSQLの数とその実行時間が確認できます。

今回質問させていただきたいのは、「Webアプリ開発における、1ページに実行されるSQLの数の目安」です。

例えば、Djangoで以下のようなモデルとフォームがあったとします。

Models

1class Job(models.Model): 2 job = models.CharField(max_length=64) 3 4class Profile(models.Model): 5 name = models.CharField(max_length=20) 6 job = models.ForeignKey(Job, on_delete=models.CASCADE)

Forms

1class ProfileForm(forms.ModelForm): 2 class Meta: 3 model = Profile 4 fields = ('name', 'job')

このProfileFormを使用すると、JobモデルのSQLが実行されます。
つまり、Profileモデルに新たにForeignKeyのフィールドを追加し、フォームクラスでそのフィールドを追加する度にSQLの数が増えてきます。
もちろん、上記以外でもSQLが実行されるケースはいくつもあります。

そこで、みなさんはどういった基準でSQLの数を気にされているのか知りたく、質問させていただきました。
私も、いわゆる「N+1問題」などを気にして、なるべくSQLの数を減らすように作業を行なっていますが、基準がわからずどこまで行うべきか迷ってしまいます。

どのような意見でも構いません。
例えば、
・「単純に10以下に抑える。」
・「数が多くても実行時間が短ければ、数はそれほど気にしない。」
などの意見があるかと思いますが、「もっとこういったことを気にするべき」などがあれば回答していただきたいと思います。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

なるべくSQLの数を減らすように作業を行なっていますが、基準がわからずどこまで行うべきか迷ってしまいます。

SQLの数を減らす事について基準なんてありません。大事なのは要件を満たす事ですから。

そもそも、こういった質問になるのは、フレームワーク選定の際の検討が十分になされていないという事ですから、そういった点を今後は気にするべきですね。

投稿2020/07/16 01:14

sazi

総合スコア25195

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

SQL の数を減らすことに意味があるとは思えません。
もちろん無駄な SQL を発行することは厳禁ですが、あるページを表示する際に必要な SQL であるならば、それは減らすことはそもそもできないはずですよね。
もっとも、特に ORM 機能を持つフレームワークの場合、E-R に基づいて取得カラム数が増えてしまう傾向があるので、そこはきちんと必要最小限に絞り込みますが。

それをやって尚減らすためには画面設計、さらには全体の設計まで見直す必要が出てきます。

要求される応答速度などの理由で結果的に SQL を整理することはあるかも知れませんが、整理が優先されるわけではないです。

投稿2020/07/16 01:01

tacsheaven

総合スコア13703

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問