mysql的多表操作查询

时间:2025-02-24

超详细mysql left join,right join,inner join用法分析 下面是例子分析

表A记录如下:

aID aNum

1 a20050111

2 a20050112

3 a20050113

4 a20050114

5 a20050115

表B记录如下:

bID bName

1 2006032401

2 2006032402

3 2006032403

4 2006032404

8 2006032408

创建这两个表SQL语句如下:

CREATE TABLE a

aID int( 1 ) AUTO_INCREMENT PRIMARY KEY ,

aNum char( 20 )

)

CREATE TABLE b(

bID int( 1 ) NOT NULL AUTO_INCREMENT PRIMARY KEY , bName char( 20 )

)

INSERT INTO a

VALUES ( 1, ‘a20050111′ ) , ( 2, ‘a20050112′ ) , ( 3, ‘a20050113′ ), ( 4, ‘a20050114′ ) , ( 5, ‘a20050115′ ) ; INSERT INTO b

VALUES ( 1, ‘ 2006032401′ ) , ( 2, ’2006032402′ ) , ( 3,’2006032403′ ) , ( 4, ’2006032404′ ) , ( 8, ’2006032408′ ) ; 实验如下:

1.left join(左联接)

sql语句如下:

SELECT * FROM a

LEFT JOIN b

ON a.aID =b.bID

结果如下:

aID aNum bID bName

1 a20050111 1 2006032401

2 a20050112 2 2006032402

4 a20050114 4 2006032404

5 a20050115 NULL NULL

(所影响的行数为 5 行)

结果说明:

left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的.

换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.aID =B.bID).

B表记录不足的地方均为NULL.

2.right join(右联接)

sql语句如下:

SELECT * FROM a

RIGHT JOING b

ON a.aID = b.bID

结果如下:

aID aNum bID bName

1 a20050111 1 2006032401

2 a20050112 2 2006032402

3 a20050113 3 2006032403

NULL NULL 8 2006032408

(所影响的行数为 5 行)

结果说明:

仔细观察一下,就会发现,和left join的结果刚好相反,这次是以右表(B)为基础的,A表不足的地方用NULL填充.

3.inner join(相等联接或内联接)

sql语句如下:

SELECT * FROM a

INNER JOIN b

ON a.aID =b.bID

等同于以下SQL句:

SELECT *

FROM a,b

WHERE a.aID = b.bID

结果如下:

aID aNum bID bName

1 a20050111 1 2006032401

2 a20050112 2 2006032402

4 a20050114 4 2006032404

结果说明:

很明显,这里只显示出了 A.aID = B.bID的记录.这说明innerjoin并不以谁为基础,它只显示符合条件的记录.

LEFT JOIN操作用于在任何的 FROM 子句中,

组合来源表的记录。使用 LEFT JOIN运算来创建一个左边外部联接。左边外部联接将包含了从第一个(左边)开始的两个表中的全部记录,即

使在第二个(右边)表中并没有相符值的记录。

语法:FROM table1 LEFT JOIN table2 ON table1.field1 compoprtable2.field2

说明:table1, table2参数用于指定要将记录组合的表的名称。 field1,field2参数指定被联接的字段的名称。且这些字段必须有相同的数据类型及包含相同类型的数据,但它们不需要有相同的 名称。

compopr 参数指定关系比较运算符: = , < , > , <= , >= 或 <> 。

如果在 INNER JOIN操作中要联接包含Memo 数据类型或 OLE Object 数据类型数据的字段,将会发生错误。

MySQL中的各种JOIN

1. 笛卡尔积(交叉连接)

在MySQL中可以为CROSS JOIN或者省略CROSS即JOIN,或者使用',' 如

SELECT * FROM table1 CROSS JOIN table2

SELECT * FROM table1 JOIN table2

SELECT * FROM table1,table2

由于其返回的结果为被连接的两个数据表的乘积,因此当有

WHERE,ON或USING条件的时候一般不建议使用,因为当数据表项目太多的时候,会非常慢。

一般使用LEFT [OUTER] JOIN或者RIGHT [OUTER] JOIN

2. 内连接INNER JOIN

在MySQL中把INNER JOIN叫做等值连接,即需要指定等值连接条件 在MySQL中CROSS和INNER JOIN被划分在一起,不明白。 参看MySQL帮助手册 http:///doc/refman/5.0/en/join.html

join_table:

table_reference [INNER | CROSS] JOIN

table_factor[join_condition]

3. MySQL中的外连接,分为左外连接和右连接,

即除了返回符合连接条件的结果之外,还要返回左表(左连接)或者右表(右连接)中不符合连接条件的结果,相对应的使用NULL对应。 a. LEFT [OUTER] JOIN

SELECT column_name FROM table1 LEFT [OUTER] JOIN table2 ONtable1.column=table2.column

除了返回符合连接条件的结果之外,还需要显示左表中不符合连接条件的数据列,相对应使用NULL对应

b. RIGHT [OUTER] JOIN

SELECT column_name FROM table1 RIGHT [OUTER] JOIN table2 ONtable1.column=table2.column

RIGHT与LEFTJOIN相似不同的仅仅是除了显示符合连接条件的结果之外,还需要显示右表中不符合连接条件的数据列,相应使用NULL对应

--------------------------------------------

添加显示条件WHERE, ON, USING

1. WHERE子句

2. ON

3. USING子句,如果连接的两个表连接条件的两个列具有相同的名字的话可以使用USING

例如

SELECT FROM LEFT JOIN USING ()

连接多余两个表的情况

举例:

mysql> SELECT artists.Artist,cds.title, genres.genre -> FROM cds

-> LEFT JOIN genres

-> ON cds.genreID = genres.genreID

-> LEFT JOIN artists

-> ON cds.artistID = artists.artistID;

或者

mysql> SELECT artists.Artist, cds.title,genres.genre -> FROM cds

-> LEFT JOIN genres

-> ON cds.genreID = genres.genreID

-> LEFT JOIN artists

-> ON cds.artistID = artists.artistID

-> WHERE (genres.genre = 'Pop');

…… 此处隐藏:7382字,全部文档内容请下载后查看。喜欢就下载吧 ……
mysql的多表操作查询.doc 将本文的Word文档下载到电脑

    精彩图片

    热门精选

    大家正在看

    × 游客快捷下载通道(下载后可以自由复制和排版)

    限时特价:7 元/份 原价:20元

    支付方式:

    开通VIP包月会员 特价:29元/月

    注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
    微信:fanwen365 QQ:370150219