1. MySQL 自己接続 MySQL では、情報を照会するときに自分自身に接続 (自己接続) する必要がある場合があるため、テーブルのエイリアスを定義する必要があります。例を見てみましょう。以下は商品購入表です。購入価格がHuihuiよりも高いすべての情報を見つける必要があります。 一般的に言えば、この表を見ると、まず次のようなステートメントで操作します。 ショッピングから*を選択 WHERE price>27 ご想像のとおり、これは非常に簡単です。データベース テーブルの詳細なデータがわからない場合や、データの量が非常に多い場合はどうすればよいでしょうか。データベース管理者は、必要なデータをすばやく見つけるために他の方法を使用する必要があります。 ステップバイステップのクエリ 最も簡単な方法は、最も簡単に思いつく方法でもあります。 SELECT price FROM shopping WHERE name='惠惠' //価格クエリの結果は27です ショッピングから*を選択 WHERE price>27 自己接続方式と比較すると、この方法では中間結果に対する手動介入が必要であり、プログラム内の自動処理操作には明らかに役立ちません。 セルフ接続方式: b.*を選択 Aとしての買い物からBとしての買い物まで ここで、a.name='惠惠' そしてa.価格<b.価格 b.idで注文 次のテーブル情報を取得できます。 注記: エイリアス a と b は名前が異なりますが、同じテーブルです。エイリアスを定義する目的は、エイリアスの削除や選択を容易にすることです。 select through (中間テーブル) を実行して、最終結果である b.* を取得します。 サブクエリ サブクエリもよく使用される方法で、select 内に select をネストします。 実装コードは次のとおりです。 ショッピングから*を選択 WHERE price>(name='惠惠' の 'shopping' から価格を選択) 結果は以下に示されており、両方の方法で得られた結果は同じであることがわかります。 参加する 内部結合 内部結合の主な機能は、テーブル内に少なくとも 1 つの一致がある場合に結果セットを返すことです。ここでの内部結合と結合は同じ機能を持つため、一緒に紹介します。 SELECT * FROM goods INNER JOIN category ON goods.id=カテゴリー.goods_id gods.idで注文する 結果は以下のようになります。 左結合 LEFT JOIN キーワードは、右側のテーブル (table_name2) に一致する行がない場合でも、左側のテーブル (table_name1) のすべての行を返します。プロジェクトを実行するときは左結合を使用することをお勧めします。ただし、テーブルの関連付けが多数あり、1 つのテーブルが a に左結合されていると同時に、b に右結合されています。この場合、右結合を追加すると、記述が簡単になる場合があります。 最初の 2 つのテーブルを適用して、左結合クエリを実行します。 SELECT goods.*,category.cate_name 商品から左へカテゴリを結合 ON goods.id=カテゴリー.goods_id goods.idで注文する 右結合 RIGHT JOIN キーワードは、左側のテーブル (table_name1) に一致する行がない場合でも、右側のテーブル (table_name2) のすべての行を返します。最初の 2 つのテーブルを適用して、右結合クエリを実行します。 a.goods_name、a.price、b.* を選択 商品として RIGHT JOIN カテゴリを b として オン a.id=b.goods_id b.idで注文 複数テーブルの関連付けの場合は、関連付けステートメントをいくつか追加するだけです。 要約する 上記はこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に少しでもお役に立てれば幸いです。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM をご愛顧いただき、ありがとうございます。 以下もご興味があるかもしれません:
|
>>: Linux で txt を mysql にインポートする方法
目次概要Node.js における CPU バウンド アプリケーションの歴史CPUを集中的に使用する操...
序文かつて、難しい問題に遭遇しました。タワークレーンからスイングハウスを落下させる必要がありましたが...
1. はじめにまず、1 台のマシンで複数のインスタンスを使用する理由という質問に答える必要があります...
前回の記事では、Zabbix のパッシブ、アクティブ、Web 監視に関するトピックについて学習しまし...
データベース アプリケーションは、アプリケーション システムに不可欠な部分です。リレーショナル デー...
正規表現は、特定のパターンに一致するテキストを検索および置換するためによく使用されます。たとえば、テ...
リストは、類似または関連する一連の項目をリストするために使用されます。順序なしリスト(箇条書きリスト...
まず、MySQL バックアップ コマンド mysqldump の一般的な操作例をいくつか紹介します。...
トリガーにより、ステートメントの実行前または実行後に他の SQL コードを実行できます。トリガーは、...
そこで、この問題を解決するために埋め込みフレームワークを導入します。具体的な原則は、フォームがデータ...
Django アプリケーションを構築して拡張していくと、必然的に特定のタスクをバックグラウンドで自動...
目次Vue+ElementUI バックグラウンド管理フレームワークでは、ElementUI とは何で...
序文単一障害点を解決するには、マスター/スレーブ ホット スタンバイ ソリューションを構成する必要が...
Zabbix独自のWEBインターフェースを例に、Web監視の設定を行います。環境: zabbix4....
mysql idは1から始まり、不連続なidの問題を解決するために自動的に増加します。強迫性障害の私...