ホームページ バックエンド開発 PHPチュートリアル Union all は非効率的です。問題を解決するには、ストアド プロシージャ、ビュー、または一時テーブルのどれを使用する必要がありますか?

Union all は非効率的です。問題を解決するには、ストアド プロシージャ、ビュー、または一時テーブルのどれを使用する必要がありますか?

Jun 23, 2016 pm 02:04 PM

Union all は非効率的です。union all にはおそらく数十のテーブルがあり、単一のテーブルの選択には 0.0003 ~ 0.002 秒しかかかりませんが、効率を向上させたい場合は、約 0.6 秒かかります。ストアド プロシージャ、ビュー、および一時を使用する必要があります。この問題を解決するにはどの方法を使用できますか?


ディスカッション (解決策) への返信
データが適切に整理されていないことは明らかです

このようなことが起こったことはありませんか?

組織 合理的であれば、そのような事態は起こりません


似たようなデータを数十のテーブルに垂直に分散させれば無理です

組織が合理的であれば、そのような事態は起こりません


似たようなデータを数十のテーブルに垂直に分散させれば、合理的ではない 合理的

これらのテーブルの構造はまったく同じではありません。その時は、表に出すのは煩雑になるだろうと考えていました。それで私たちは別れました。しかし後で、要約する必要があるときに問題が発生したことが判明しました。


誰か良いアイデアはありますか?以前に作成したテーブルはいくつかの機能に適用されています。今すぐ変更するには大きすぎるプロジェクトです。

テーブルの構造を教えていただけますか?
同じではないのに、重ね合わせることに何の意味があるのでしょうか?

テーブルの構造を教えていただけますか?

同じではないのに、重ね合わせることに何の意味があるのでしょうか?

今確認したところ、テーブルは7つあり、
1. 売上伝票、赤字の売上伝票

2. 仕入伝票、赤字の仕入伝票

3. 領収書、支払伝票、振込伝票 の7つです。

このうち、グループ 1 とグループ 2 の構造は同じであり、グループ 1 とグループ 2 で異なるフィールドは 1 つだけです。
3 つのグループの回収伝票と支払伝票にも、転送伝票の構造が 1 つだけ異なります。



なお、グループ 1 とグループ 2 の内部テーブル構造は同じです。グループ 1 とグループ 2 で異なるフィールドは 1 つだけです。

グループ 1 とグループ 2 の異なるフィールドは次のとおりです。
グループ 1 には「販売注文番号、顧客コード」があります。

2 つのグループには「注文番号、サプライヤー コード」が含まれます。

グループ 1 とグループ 2 のテーブル構造は次のようになります。これらを 1 つのテーブルにマージできますか?



データ量はどれくらいですか?サブテーブルの状況に到達する時が来ました。テーブルを分割する場合、このレベルの分割は合理的ではありません。

Union を使用するのは正しいです!
これらの 7 つのテーブルは並列です。接続したくても、結合することしかできません。

データ量はどれくらいですか?サブテーブルの状況に到達する時が来ました。テーブルを分割する場合、このレベルの分割は合理的ではありません。

実際、それらはすべて異なることを説明しています。そのため、テーブルに分かれています。


1. 販売伝票、赤字の売上伝票

2. 仕入伝票、赤字の購入伝票

3. 受取伝票、支払伝票、振込伝票。




Unionを使えばいいんじゃないでしょうか?
これら 7 つのテーブルは並列です。結合したくても、結合することしかできません。

グループ 1 とグループ 2 のテーブル構造をマージし、グループ 3 のテーブル構造をマージするのは合理的ですか?


必要ないですよね?一部の機能に適用されていると言ってませんでしたか?


必要ないですよね?一部の機能に適用されていると言ってませんでしたか?

は、追加、削除、確認、変更を行う独自の機能です。この設計により、将来的に対処が難しい他の問題が発生するかどうかはわかりません。

もしよろしければ、ビジネス プロセスを説明してください

今の 7 つのテーブルは、次のいくつかの関数のデータ ソースです。


例えば、仕訳機能があります。この機能は、先ほどの7つのテーブルのレコードから、「銀行預金と現金」の2つの口座の詳細なレコードを検索するものです。これら 2 つの預金の詳細を抽出し、概要で表示する必要があります。

2つ目は口座詳細機能で、これも先ほどの7つのテーブルから「銀行預金と現金」を除いた全ての口座の詳細記録を検索し、一覧で表示するものです。

3 番目はアカウント概要テーブルです。これは、特定の期間内のアカウントごとのすべてのバウチャーの概要です。


4 番目の総勘定元帳には、各口座の詳細な記録がすべて表示されます。

あまり良い説明ではないかもしれません。すみません。

すべて結合した後に注文しましたか? そうでなければ、それほど大きな違いはないはずです


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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHPのさまざまなエラータイプを説明します(通知、警告、致命的なエラー、解析エラー)。 PHPのさまざまなエラータイプを説明します(通知、警告、致命的なエラー、解析エラー)。 Apr 08, 2025 am 12:03 AM

PHPには4つの主要なエラータイプがあります。1。notice:わずかなものは、未定義の変数へのアクセスなど、プログラムを中断しません。 2。警告:通知よりも深刻で、ファイルを含むなど、プログラムを終了しません。 3。ファタラー:最も深刻なのは、機能を呼び出すなど、プログラムを終了します。 4。ParseError:構文エラーは、エンドタグの追加を忘れるなど、プログラムの実行を防ぎます。

PHPとPython:2つの一般的なプログラミング言語を比較します PHPとPython:2つの一般的なプログラミング言語を比較します Apr 14, 2025 am 12:13 AM

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

PHPでの安全なパスワードハッシュ(例:Password_hash、password_verify)を説明します。 MD5またはSHA1を使用してみませんか? PHPでの安全なパスワードハッシュ(例:Password_hash、password_verify)を説明します。 MD5またはSHA1を使用してみませんか? Apr 17, 2025 am 12:06 AM

PHPでは、Password_hashとpassword_verify関数を使用して安全なパスワードハッシュを実装する必要があり、MD5またはSHA1を使用しないでください。 1)password_hashセキュリティを強化するために、塩値を含むハッシュを生成します。 2)password_verifyハッシュ値を比較して、パスワードを確認し、セキュリティを確保します。 3)MD5とSHA1は脆弱であり、塩の値が不足しており、最新のパスワードセキュリティには適していません。

アクション中のPHP:実際の例とアプリケーション アクション中のPHP:実際の例とアプリケーション Apr 14, 2025 am 12:19 AM

PHPは、電子商取引、コンテンツ管理システム、API開発で広く使用されています。 1)eコマース:ショッピングカート機能と支払い処理に使用。 2)コンテンツ管理システム:動的コンテンツの生成とユーザー管理に使用されます。 3)API開発:RESTFUL API開発とAPIセキュリティに使用されます。パフォーマンスの最適化とベストプラクティスを通じて、PHPアプリケーションの効率と保守性が向上します。

HTTPリクエストメソッド(取得、投稿、配置、削除など)とは何ですか?それぞれを使用する必要がありますか? HTTPリクエストメソッド(取得、投稿、配置、削除など)とは何ですか?それぞれを使用する必要がありますか? Apr 09, 2025 am 12:09 AM

HTTPリクエストメソッドには、それぞれリソースを取得、送信、更新、削除するために使用されるGET、POST、PUT、および削除が含まれます。 1. GETメソッドは、リソースを取得するために使用され、読み取り操作に適しています。 2. POSTメソッドはデータの送信に使用され、新しいリソースを作成するためによく使用されます。 3. PUTメソッドは、リソースの更新に使用され、完全な更新に適しています。 4.削除メソッドは、リソースの削除に使用され、削除操作に適しています。

PHP:Web開発の重要な言語 PHP:Web開発の重要な言語 Apr 13, 2025 am 12:08 AM

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

PHP OOPで、self ::、parent ::、and static ::の違いを説明します。 PHP OOPで、self ::、parent ::、and static ::の違いを説明します。 Apr 09, 2025 am 12:04 AM

Phpoopでは、self ::は現在のクラスを指し、親::は親クラスを指し、静的::は後期静的結合に使用されます。 1.Self ::静的方法と一定の呼び出しに使用されますが、後期静的結合をサポートしていません。 2.Parent ::サブクラスには、親クラスのメソッドを呼び出すために使用され、プライベートメソッドにアクセスできません。 3.Static ::継承と多型に適した後期静的結合をサポートしますが、コードの読みやすさに影響を与える可能性があります。

PHPは、ファイルを安全に処理する方法をどのように処理しますか? PHPは、ファイルを安全に処理する方法をどのように処理しますか? Apr 10, 2025 am 09:37 AM

PHPは、$ \ _ファイル変数を介してファイルのアップロードを処理します。セキュリティを確保するための方法には次のものが含まれます。1。アップロードエラー、2。ファイルの種類とサイズを確認する、3。ファイル上書きを防ぐ、4。ファイルを永続的なストレージの場所に移動します。

See all articles