目次
接続クエリ
デカルト積現象を回避する: 複数のテーブルを接続する場合は接続条件を追加しますを指定し、この条件を満たすレコードをフィルタリングします
部門名を問い合わせる各従業員の従業員名と部門
クエリになります。
内连接和外连接的特点
多表连接
ホームページ データベース mysql チュートリアル MySql での接続クエリの問題を解決する方法

MySql での接続クエリの問題を解決する方法

May 26, 2023 pm 08:48 PM
mysql

    接続クエリ

    複数テーブルの接続クエリを実行する場合は、フィールドが属するテーブルを指定する必要があります。これにより、クエリの効率が向上します。フィールドが属するテーブルを指定しない場合、データベースは各テーブルからこのフィールドを検索します。

    • e. フィールド名: emp テーブルからフィールドを取得することを意味します

    • emp as e: テーブルのエイリアス メカニズム。as を省略して、emp e

    • 接続クエリとして直接記述することもできます。データをクエリするには複数のテーブルを関連付ける必要があるクロステーブル クエリと呼ばれます

    • emp テーブルと dept テーブルを組み合わせてデータをクエリします。emp から従業員名を取得します。

    #注: クエリを接続するときは、デカルト積現象を避けるために、関連する条件を必ず記述してください

    接続クエリの分類

    ##文法年代による分類

    #SQL92:

    1992 年に登場した構文

    #sql92 の欠点: 構造が明確ではないこと、テーブルの接続条件、後段でさらにフィルタリングするための条件がすべて where の後に配置されることです

    • SQL99:
    • 1999 年に登場した構文 (学習中心)

    sql99 の利点: 表 接続条件とクエリ条件が分離されている接続後にさらにフィルタリングする必要がある場合は、後でどこを追加し続けます。複数のテーブルを接続するとより明確になります。

    • テーブルに従って接続します。メソッドの分類

    内部結合: 等結合、非等結合、自己結合、内部は省略でき、通常は追加されません

    テーブル A 内部結合テーブル B (関連付け条件あり)

    • 外部結合: 左外部結合 (左結合)、右外部結合 (右結合)、外部は省略でき、通常は追加できません

    テーブル A の左外部結合 関連付け条件のテーブル B

    • テーブル B の右外部結合 関連付け条件のテーブル A

    • テーブルとの左結合左の表が優先され、右の表と比較して、左の表と等しいか不平等な場合は表示され、右の表には条件を満たす条件が表示され、条件を満たさない条件は表示されません。 (右結合はその逆です)

    • 左結合で完了できる関数は右結合でも完了できます

    • 完全結合の場合、接続されている 2 つのテーブルは両方ともメイン テーブルであり、クエリが可能です。

    • デカルト積現象

    クエリのために 2 つのテーブルが接続され、接続条件が指定されていない場合、最終的なクエリ結果の数は次のようになります。 2 つのテーブルのエントリ数の積。この現象は次のように呼ばれます: デカルト積現象 (デカルトによって発見され、これは数学的な現象です)

    デカルト積現象を回避する: 複数のテーブルを接続する場合は接続条件を追加しますを指定し、この条件を満たすレコードをフィルタリングします

    一致プロセス中に一致数は減りませんが、次に従ってフィルタリングされるため、最終的なクエリ結果の数は少なくなります。接続条件

    • ##デカルト積現象により、テーブルの接続数が増えると効率が低下することがわかります。テーブルの接続数を避けるようにしてください。

    • 内部結合と等価結合

      条件が等しいので等結合(等しい接続条件のデータ)と呼ばれます

    部門名を問い合わせる各従業員の従業員名と部門

    emp eテーブルとdept dテーブルを表示します。接続するには、接続条件は次のとおりです: e.deptno = d.deptno

    	--sql92的缺点:结构不清晰,表的连接条件,和后期进一步筛选的条件,都放到了where后面
    
    	select 
    		e.ename,d.dname
    	from
    		emp e, dept d
    	where
    		e.deptno = d.deptno;
    		
    	--sql99优点:表连接的条件是独立的,连接之后,如果还需要进一步筛选,再往后继续添加where		
    	select 
    		e.ename,d.dname
    	from
    		emp e
    	--inner可以省略(带着inner可读性更好)
    	(inner) join
    		dept d
    	on
    		e.deptno = d.deptno;
    ログイン後にコピー
    Inner join self -join

    テーブル接続は 1 つだけであるため、具体的なクエリ方法は 1 つのテーブルを 2 つのテーブルが接続しているものとして扱うことです。そのため、自己結合

    クエリになります。

    ##1 つのテーブルは 2 つのテーブルとして表示され、emp e は従業員テーブルを表し、emp m はリーダー テーブルも表します

    接続条件: e.mgr = m.empno 社員リーダー番号 = リーダー社員番号

    --SQL92
    select e.ename, m.ename from emp e, emp m where e.mgr=m.empno;
    
    --SQL99
    select 
    	a.ename as '员工名', b.ename as '领导名'
    from
    	emp e
    join
    	emp m
    on
    	e.mgr = m.empno;
    ログイン後にコピー
    内部結合非等価接続

    接続条件が同値関係ではないため、これは非等価接続と呼ばれます。

    給与が 2000 を超える従業員情報を表示し、その従業員が所属する部門名を表示します。

    --采用 SQL92 语法
    select 
    	e.ename, e.sal, d.dname 
    from 
    	emp e, dept d 
    where 
    	e.deptno=d.deptno and e.sal > 2000;
    	
    --采用 SQL99 语法
    select 
    	e.ename, e.sal, d.dname 
    from 
    	emp e 
    (inner) join 
    	dept d 
    on 
    	e.deptno=d.deptno 
    where 
    	e.sal>2000;
    ログイン後にコピー

    各従業員の給与等級を調べ、従業員名、給与、給与等級の表示を要求します

    select 
    	e.ename, e.sal, s.grade
    from
    	emp e
    (inner) join
    	salgrade s
    on
    	e.sal between s.losal and s.hisal;
    ログイン後にコピー
    外部接続

    外部接続 接続: 外部接続では、 2 つのテーブル間の接続により、プライマリとセカンダリの関係が作成されます。メイン クエリはプライマリ テーブルのデータであり、セカンダリ テーブルは関連付けを使用してクエリされます。つまり、相手にプライマリ テーブルと一致するレコードがない場合、デフォルトの相手は null、外部キーワードは省略可能

    右外部結合: 右を持つものは右外部結合です。つまり、結合キーワードの右側のテーブルはメインテーブルとみなされ、主にこれを結合します テーブル内のすべてのデータがクエリされ、左側のテーブルが関連付けでクエリされます

    左外部結合: 左を持つものこれは、結合キーワードの左側にあるテーブルをメイン テーブルとして扱い、主にこのテーブル内のすべてのデータをクエリし、関連付け ## を使用して右側のテーブルをクエリすることを意味します。
    • #**注: 右結合には左結合の書き込みメソッドがあり、左接続には右接続の書き込みメソッドがあります**

      查询每个员工的上级领导,要求显示所有员工的名字和领导名 , 如果某个员工没有领导 , 那么该员工也必须显示出来

      --左连接
      select 
      	a.ename as '员工名', b.ename as '领导名'
      from
      	emp a
      left (outer) join
      	emp b
      on
      	a.mgr = b.empno; 
      
      --右连接
      select 
      	a.ename as '员工名', b.ename as '领导名'
      from
      	emp b
      right (outer) join
      	emp a
      on
      	a.mgr = b.empno;
      ログイン後にコピー

      内连接和外连接的特点

      内连接:A表和B表连接,A和B两张表没有主次关系是平等的 , 查询时只是将能够匹配上连接条件的数据查询出来 , 即如果没有匹配的就查询不出来 , inner关键字可以省略

      外连接: 在外连接当中,两张表连接产生了主次关系 , 主要查询的是主表的数据 , 捎带着关联查询次表 , 即如果对方没有记录和我主表匹配 , 那么默认对方是null , outer关键字可以省略

      注意: 区分内外连接的办法是通过 right 和 left 关键字 , 不是通过 inner 和 outer 因为它们都可以省略 , 并且外连接的查询结果条数一定是大于等于内连接的查询结果条数

      显示员工信息,并显示所属的部门名称

      select 
      	e.ename,d.dname
      from
      	emp e
      join
      	dept d
      on
      	e.deptno = d.deptno;
      ログイン後にコピー

      MySql での接続クエリの問題を解決する方法

      显示员工信息,并显示所属的部门名称,如果某一个部门没有员工,那么该部门也必须显示出来

      --外连接(右外连接)
      select 
      	e.ename,d.dname
      from
      	emp e 
      --outer是可以省略的,带着可读性强
      --right代表什么:表示将join关键字右边的这张表看成主表,主要是为了将这张表的数据全部查询出来,捎带着关联查询左边的表
      right (outer) join 
      	dept d
      on
      	e.deptno = d.deptno;
      
      
      --外连接(左外连接)
      select 
      	e.ename,d.dname
      from
      	dept d 
      --outer是可以省略的,带着可读性强
      left (outer) join 
      	emp e
      on
      	e.deptno = d.deptno;
      ログイン後にコピー

      MySql での接続クエリの問題を解決する方法

      多表连接

      一条SQL中内连接和外连接可以混合 , 都可以出现

      --表示一: a 和 b 进行内连接 , a 和 c 进行内连接 , a 和 d 进行右外连接(推荐)
      
      --表示二: a 和 b 的内连接结果去内连接 c 的结果再去右外连接 d
      select 
      	...
      from
      	a
      join
      	b
      on
      	a和b的连接条件
      join
      	c
      on
      	a和c的连接条件
      right join
      	d
      on
      	a和d的连接条件
      ログイン後にコピー

      找出每个员工的部门名称以及工资等级,要求显示员工名、部门名、薪资、薪资等级

      	select 
      		e.ename,e.sal,d.dname,s.grade
      	from
      		emp e
      	join
      		dept d
      	on 
      		e.deptno = d.deptno
      	join
      		salgrade s
      	on
      		e.sal between s.losal and s.hisal;
      ログイン後にコピー

      查询结果

      	+--------+---------+------------+-------+
      	| ename  | sal     | dname      | grade |
      	+--------+---------+------------+-------+
      	| SMITH  |  800.00 | RESEARCH   |     1 |
      	| ALLEN  | 1600.00 | SALES      |     3 |
      	| WARD   | 1250.00 | SALES      |     2 |
      	| JONES  | 2975.00 | RESEARCH   |     4 |
      	| MARTIN | 1250.00 | SALES      |     2 |
      	| BLAKE  | 2850.00 | SALES      |     4 |
      	| CLARK  | 2450.00 | ACCOUNTING |     4 |
      	| SCOTT  | 3000.00 | RESEARCH   |     4 |
      	| KING   | 5000.00 | ACCOUNTING |     5 |
      	| TURNER | 1500.00 | SALES      |     3 |
      	| ADAMS  | 1100.00 | RESEARCH   |     1 |
      	| JAMES  |  950.00 | SALES      |     1 |
      	| FORD   | 3000.00 | RESEARCH   |     4 |
      	| MILLER | 1300.00 | ACCOUNTING |     2 |
      	+--------+---------+------------+-------+
      ログイン後にコピー

      找出每个员工的部门名称以及工资等级,还有上级领导,要求显示员工名、领导名、部门名、薪资、薪资等级

      	select 
      		e.ename,e.sal,d.dname,s.grade,l.ename
      	from
      		emp e
      	join
      		dept d
      	on 
      		e.deptno = d.deptno
      	join
      		salgrade s
      	on
      		e.sal between s.losal and s.hisal
      	left join
      		emp l
      	on
      		e.mgr = l.empno;
      ログイン後にコピー

      查询结果

      	+--------+---------+------------+-------+-------+
      	| ename  | sal     | dname      | grade | ename |
      	+--------+---------+------------+-------+-------+
      	| SMITH  |  800.00 | RESEARCH   |     1 | FORD  |
      	| ALLEN  | 1600.00 | SALES      |     3 | BLAKE |
      	| WARD   | 1250.00 | SALES      |     2 | BLAKE |
      	| JONES  | 2975.00 | RESEARCH   |     4 | KING  |
      	| MARTIN | 1250.00 | SALES      |     2 | BLAKE |
      	| BLAKE  | 2850.00 | SALES      |     4 | KING  |
      	| CLARK  | 2450.00 | ACCOUNTING |     4 | KING  |
      	| SCOTT  | 3000.00 | RESEARCH   |     4 | JONES |
      	| KING   | 5000.00 | ACCOUNTING |     5 | NULL  |
      	| TURNER | 1500.00 | SALES      |     3 | BLAKE |
      	| ADAMS  | 1100.00 | RESEARCH   |     1 | SCOTT |
      	| JAMES  |  950.00 | SALES      |     1 | BLAKE |
      	| FORD   | 3000.00 | RESEARCH   |     4 | JONES |
      	| MILLER | 1300.00 | ACCOUNTING |     2 | CLARK |
      	+--------+---------+------------+-------+-------+
      ログイン後にコピー

      以上がMySql での接続クエリの問題を解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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)

    phpmyadminを開く方法 phpmyadminを開く方法 Apr 10, 2025 pm 10:51 PM

    次の手順でphpmyadminを開くことができます。1。ウェブサイトコントロールパネルにログインします。 2。phpmyadminアイコンを見つけてクリックします。 3。MySQL資格情報を入力します。 4.「ログイン」をクリックします。

    MySQL:世界で最も人気のあるデータベースの紹介 MySQL:世界で最も人気のあるデータベースの紹介 Apr 12, 2025 am 12:18 AM

    MySQLはオープンソースのリレーショナルデータベース管理システムであり、主にデータを迅速かつ確実に保存および取得するために使用されます。その実用的な原則には、クライアントリクエスト、クエリ解像度、クエリの実行、返品結果が含まれます。使用法の例には、テーブルの作成、データの挿入とクエリ、および参加操作などの高度な機能が含まれます。一般的なエラーには、SQL構文、データ型、およびアクセス許可、および最適化の提案には、インデックスの使用、最適化されたクエリ、およびテーブルの分割が含まれます。

    MySQLの場所:データベースとプログラミング MySQLの場所:データベースとプログラミング Apr 13, 2025 am 12:18 AM

    データベースとプログラミングにおけるMySQLの位置は非常に重要です。これは、さまざまなアプリケーションシナリオで広く使用されているオープンソースのリレーショナルデータベース管理システムです。 1)MySQLは、効率的なデータストレージ、組織、および検索機能を提供し、Web、モバイル、およびエンタープライズレベルのシステムをサポートします。 2)クライアントサーバーアーキテクチャを使用し、複数のストレージエンジンとインデックスの最適化をサポートします。 3)基本的な使用には、テーブルの作成とデータの挿入が含まれ、高度な使用法にはマルチテーブル結合と複雑なクエリが含まれます。 4)SQL構文エラーやパフォーマンスの問題などのよくある質問は、説明コマンドとスロークエリログを介してデバッグできます。 5)パフォーマンス最適化方法には、インデックスの合理的な使用、最適化されたクエリ、およびキャッシュの使用が含まれます。ベストプラクティスには、トランザクションと準備された星の使用が含まれます

    なぜMySQLを使用するのですか?利点と利点 なぜMySQLを使用するのですか?利点と利点 Apr 12, 2025 am 12:17 AM

    MySQLは、そのパフォーマンス、信頼性、使いやすさ、コミュニティサポートに選択されています。 1.MYSQLは、複数のデータ型と高度なクエリ操作をサポートし、効率的なデータストレージおよび検索機能を提供します。 2.クライアントサーバーアーキテクチャと複数のストレージエンジンを採用して、トランザクションとクエリの最適化をサポートします。 3.使いやすく、さまざまなオペレーティングシステムとプログラミング言語をサポートしています。 4.強力なコミュニティサポートを提供し、豊富なリソースとソリューションを提供します。

    Apacheのデータベースに接続する方法 Apacheのデータベースに接続する方法 Apr 13, 2025 pm 01:03 PM

    Apacheはデータベースに接続するには、次の手順が必要です。データベースドライバーをインストールします。 web.xmlファイルを構成して、接続プールを作成します。 JDBCデータソースを作成し、接続設定を指定します。 JDBC APIを使用して、接続の取得、ステートメントの作成、バインディングパラメーター、クエリまたは更新の実行、結果の処理など、Javaコードのデータベースにアクセスします。

    DockerによるMySQLを開始する方法 DockerによるMySQLを開始する方法 Apr 15, 2025 pm 12:09 PM

    DockerでMySQLを起動するプロセスは、次の手順で構成されています。MySQLイメージをプルしてコンテナを作成および起動し、ルートユーザーパスワードを設定し、ポート検証接続をマップしてデータベースを作成し、ユーザーはすべての権限をデータベースに付与します。

    MySQLの役割:Webアプリケーションのデータベース MySQLの役割:Webアプリケーションのデータベース Apr 17, 2025 am 12:23 AM

    WebアプリケーションにおけるMySQLの主な役割は、データを保存および管理することです。 1.MYSQLは、ユーザー情報、製品カタログ、トランザクションレコード、その他のデータを効率的に処理します。 2。SQLクエリを介して、開発者はデータベースから情報を抽出して動的なコンテンツを生成できます。 3.MYSQLは、クライアントサーバーモデルに基づいて機能し、許容可能なクエリ速度を確保します。

    Centosはmysqlをインストールします Centosはmysqlをインストールします Apr 14, 2025 pm 08:09 PM

    CentOSにMySQLをインストールするには、次の手順が含まれます。適切なMySQL Yumソースの追加。 yumを実行して、mysql-serverコマンドをインストールして、mysqlサーバーをインストールします。ルートユーザーパスワードの設定など、MySQL_SECURE_INSTALLATIONコマンドを使用して、セキュリティ設定を作成します。必要に応じてMySQL構成ファイルをカスタマイズします。 MySQLパラメーターを調整し、パフォーマンスのためにデータベースを最適化します。

    See all articles