ホームページ  >  記事  >  データベース  >  MySql での接続クエリの問題を解決する方法

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

WBOY
WBOY転載
2023-05-26 20:48:401253ブラウズ

    接続クエリ

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

    • 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 サイトの他の関連記事を参照してください。

    声明:
    この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。