站長(zhǎng)資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        mysql怎樣兩表查詢(xún)?

        mysql兩表查詢(xún)的方法:1、使用“select 字段列表 from 表1,表2 [where 條件]”進(jìn)行查詢(xún);2、使用“SELECT 字段列表 FROM 表1 關(guān)鍵字 JOIN 表2 ON 表1.字段 = 表2.字段;”進(jìn)行查詢(xún)。

        mysql怎樣兩表查詢(xún)?

        mysql怎樣兩表查詢(xún)?下面本篇文章給大家介紹一下mysql中進(jìn)行多表查詢(xún)的方法。有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)大家有所幫助。

        多表聯(lián)合查詢(xún)

        #創(chuàng)建表和數(shù)據(jù)  #創(chuàng)建部門(mén) CREATE TABLE IF NOT EXISTS dept (     did int not null auto_increment PRIMARY KEY,     dname VARCHAR(50) not null COMMENT '部門(mén)名稱(chēng)' )ENGINE=INNODB DEFAULT charset utf8;   #添加部門(mén)數(shù)據(jù) INSERT INTO `dept` VALUES ('1', '教學(xué)部'); INSERT INTO `dept` VALUES ('2', '銷(xiāo)售部'); INSERT INTO `dept` VALUES ('3', '市場(chǎng)部'); INSERT INTO `dept` VALUES ('4', '人事部'); INSERT INTO `dept` VALUES ('5', '鼓勵(lì)部');  -- 創(chuàng)建人員 DROP TABLE IF EXISTS `person`; CREATE TABLE `person` (   `id` int(11) NOT NULL AUTO_INCREMENT,   `name` varchar(50) NOT NULL,   `age` tinyint(4) DEFAULT '0',   `sex` enum('男','女','人妖') NOT NULL DEFAULT '人妖',   `salary` decimal(10,2) NOT NULL DEFAULT '250.00',   `hire_date` date NOT NULL,   `dept_id` int(11) DEFAULT NULL,   PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8;  -- 添加人員數(shù)據(jù)  -- 教學(xué)部 INSERT INTO `person` VALUES ('1', 'alex', '28', '人妖', '53000.00', '2010-06-21', '1'); INSERT INTO `person` VALUES ('2', 'wupeiqi', '23', '男', '8000.00', '2011-02-21', '1'); INSERT INTO `person` VALUES ('3', 'egon', '30', '男', '6500.00', '2015-06-21', '1'); INSERT INTO `person` VALUES ('4', 'jingnvshen', '18', '女', '6680.00', '2014-06-21', '1');  -- 銷(xiāo)售部 INSERT INTO `person` VALUES ('5', '歪歪', '20', '女', '3000.00', '2015-02-21', '2'); INSERT INTO `person` VALUES ('6', '星星', '20', '女', '2000.00', '2018-01-30', '2'); INSERT INTO `person` VALUES ('7', '格格', '20', '女', '2000.00', '2018-02-27', '2'); INSERT INTO `person` VALUES ('8', '周周', '20', '女', '2000.00', '2015-06-21', '2');  -- 市場(chǎng)部 INSERT INTO `person` VALUES ('9', '月月', '21', '女', '4000.00', '2014-07-21', '3'); INSERT INTO `person` VALUES ('10', '安琪', '22', '女', '4000.00', '2015-07-15', '3');  -- 人事部 INSERT INTO `person` VALUES ('11', '周明月', '17', '女', '5000.00', '2014-06-21', '4');  -- 鼓勵(lì)部 INSERT INTO `person` VALUES ('12', '蒼老師', '33', '女', '1000000.00', '2018-02-21', null);

        多表查詢(xún)語(yǔ)法

        select  字段1,字段2... from 表1,表2... [where 條件]

        注意: 如果不加條件直接進(jìn)行查詢(xún),則會(huì)出現(xiàn)以下效果,這種結(jié)果我們稱(chēng)之為 笛卡爾乘積

        #查詢(xún)?nèi)藛T和部門(mén)所有信息 select * from person,dept 

        笛卡爾乘積公式 : A表中數(shù)據(jù)條數(shù) * B表中數(shù)據(jù)條數(shù) = 笛卡爾乘積.

        #笛卡爾乘積示例  mysql> select * from person ,dept; +----+----------+-----+-----+--------+------+-----+--------+ | id | name     | age | sex | salary | did  | did | dname  | +----+----------+-----+-----+--------+------+-----+--------+ |  1 | alex     |  28 | 女  |  53000 |    1 |   1 | python | |  1 | alex     |  28 | 女  |  53000 |    1 |   2 | linux  | |  1 | alex     |  28 | 女  |  53000 |    1 |   3 | 明教   | |  2 | wupeiqi  |  23 | 女  |  29000 |    1 |   1 | python | |  2 | wupeiqi  |  23 | 女  |  29000 |    1 |   2 | linux  | |  2 | wupeiqi  |  23 | 女  |  29000 |    1 |   3 | 明教   | |  3 | egon     |  30 | 男  |  27000 |    1 |   1 | python | |  3 | egon     |  30 | 男  |  27000 |    1 |   2 | linux  | |  3 | egon     |  30 | 男  |  27000 |    1 |   3 | 明教   | |  4 | oldboy   |  22 | 男  |      1 |    2 |   1 | python | |  4 | oldboy   |  22 | 男  |      1 |    2 |   2 | linux  | |  4 | oldboy   |  22 | 男  |      1 |    2 |   3 | 明教   | |  5 | jinxin   |  33 | 女  |  28888 |    1 |   1 | python | |  5 | jinxin   |  33 | 女  |  28888 |    1 |   2 | linux  | |  5 | jinxin   |  33 | 女  |  28888 |    1 |   3 | 明教   | |  6 | 張無(wú)忌   |  20 | 男  |   8000 |    3 |   1 | python | |  6 | 張無(wú)忌   |  20 | 男  |   8000 |    3 |   2 | linux  | |  6 | 張無(wú)忌   |  20 | 男  |   8000 |    3 |   3 | 明教   | |  7 | 令狐沖   |  22 | 男  |   6500 | NULL |   1 | python | |  7 | 令狐沖   |  22 | 男  |   6500 | NULL |   2 | linux  | |  7 | 令狐沖   |  22 | 男  |   6500 | NULL |   3 | 明教   | |  8 | 東方不敗 |  23 | 女  |  18000 | NULL |   1 | python | |  8 | 東方不敗 |  23 | 女  |  18000 | NULL |   2 | linux  | |  8 | 東方不敗 |  23 | 女  |  18000 | NULL |   3 | 明教   | +----+----------+-----+-----+--------+------+-----+--------+
        #查詢(xún)?nèi)藛T和部門(mén)所有信息 select * from person,dept where person.did = dept.did;

        #注意: 多表查詢(xún)時(shí),一定要找到兩個(gè)表中相互關(guān)聯(lián)的字段,并且作為條件使用

        示例

        mysql> select * from person,dept where person.did = dept.did; +----+---------+-----+-----+--------+-----+-----+--------+ | id | name    | age | sex | salary | did | did | dname  | +----+---------+-----+-----+--------+-----+-----+--------+ |  1 | alex    |  28 | 女  |  53000 |   1 |   1 | python | |  2 | wupeiqi |  23 | 女  |  29000 |   1 |   1 | python | |  3 | egon    |  30 | 男  |  27000 |   1 |   1 | python | |  4 | oldboy  |  22 | 男  |      1 |   2 |   2 | linux  | |  5 | jinxin  |  33 | 女  |  28888 |   1 |   1 | python | |  6 | 張無(wú)忌  |  20 | 男  |   8000 |   3 |   3 | 明教   | |  7 | 令狐沖  |  22 | 男  |   6500 |   2 |   2 | linux  | +----+---------+-----+-----+--------+-----+-----+--------+ 7 rows in set

        mysql怎樣兩表查詢(xún)?

        多表鏈接查詢(xún)

        #多表連接查詢(xún)語(yǔ)法(重點(diǎn))  SELECT 字段列表     FROM 表1  INNER|LEFT|RIGHT JOIN  表2 ON 表1.字段 = 表2.字段;

        1 內(nèi)連接查詢(xún) (只顯示符合條件的數(shù)據(jù))

        #查詢(xún)?nèi)藛T和部門(mén)所有信息 select * from person inner join dept  on person.did =dept.did;

        效果: 大家可能會(huì)發(fā)現(xiàn), 內(nèi)連接查詢(xún)與多表聯(lián)合查詢(xún)的效果是一樣的.

        mysql怎樣兩表查詢(xún)?

        mysql> select * from person inner join  dept  on  person.did =dept.did; +----+---------+-----+-----+--------+-----+-----+--------+ | id | name    | age | sex | salary | did | did | dname  | +----+---------+-----+-----+--------+-----+-----+--------+ |  1 | alex    |  28 | 女  |  53000 |   1 |   1 | python | |  2 | wupeiqi |  23 | 女  |  29000 |   1 |   1 | python | |  3 | egon    |  30 | 男  |  27000 |   1 |   1 | python | |  4 | oldboy  |  22 | 男  |      1 |   2 |   2 | linux  | |  5 | jinxin  |  33 | 女  |  28888 |   1 |   1 | python | |  6 | 張無(wú)忌  |  20 | 男  |   8000 |   3 |   3 | 明教   | |  7 | 令狐沖  |  22 | 男  |   6500 |   2 |   2 | linux  | +----+---------+-----+-----+--------+-----+-----+--------+ 7 rows in set

        2 左外連接查詢(xún) (左邊表中的數(shù)據(jù)優(yōu)先全部顯示)

        #查詢(xún)?nèi)藛T和部門(mén)所有信息 select * from person left join  dept  on  person.did =dept.did;

        效果:人員表中的數(shù)據(jù)全部都顯示,而 部門(mén)表中的數(shù)據(jù)符合條件的才會(huì)顯示,不符合條件的會(huì)以 null 進(jìn)行填充.

        mysql怎樣兩表查詢(xún)?

        mysql> select * from person left join  dept  on  person.did =dept.did; +----+----------+-----+-----+--------+------+------+--------+ | id | name     | age | sex | salary | did  | did  | dname  | +----+----------+-----+-----+--------+------+------+--------+ |  1 | alex     |  28 | 女  |  53000 |    1 |    1 | python | |  2 | wupeiqi  |  23 | 女  |  29000 |    1 |    1 | python | |  3 | egon     |  30 | 男  |  27000 |    1 |    1 | python | |  5 | jinxin   |  33 | 女  |  28888 |    1 |    1 | python | |  4 | oldboy   |  22 | 男  |      1 |    2 |    2 | linux  | |  7 | 令狐沖   |  22 | 男  |   6500 |    2 |    2 | linux  | |  6 | 張無(wú)忌   |  20 | 男  |   8000 |    3 |    3 | 明教   | |  8 | 東方不敗 |  23 | 女  |  18000 | NULL | NULL | NULL   | +----+----------+-----+-----+--------+------+------+--------+ 8 rows in set

        3 右外連接查詢(xún) (右邊表中的數(shù)據(jù)優(yōu)先全部顯示)

        #查詢(xún)?nèi)藛T和部門(mén)所有信息 select * from person right join  dept  on  person.did =dept.did;

        效果:正好與[左外連接相反]

        mysql> select * from person right join  dept  on  person.did =dept.did; +----+---------+-----+-----+--------+-----+-----+--------+ | id | name    | age | sex | salary | did | did | dname  | +----+---------+-----+-----+--------+-----+-----+--------+ |  1 | alex    |  28 | 女  |  53000 |   1 |   1 | python | |  2 | wupeiqi |  23 | 女  |  29000 |   1 |   1 | python | |  3 | egon    |  30 | 男  |  27000 |   1 |   1 | python | |  4 | oldboy  |  22 | 男  |      1 |   2 |   2 | linux  | |  5 | jinxin  |  33 | 女  |  28888 |   1 |   1 | python | |  6 | 張無(wú)忌  |  20 | 男  |   8000 |   3 |   3 | 明教   | |  7 | 令狐沖  |  22 | 男  |   6500 |   2 |   2 | linux  | +----+---------+-----+-----+--------+-----+-----+--------+ 7 rows in set

        4 全連接查詢(xún)(顯示左右表中全部數(shù)據(jù))

          全連接查詢(xún):是在內(nèi)連接的基礎(chǔ)上增加 左右兩邊沒(méi)有顯示的數(shù)據(jù)
          注意: mysql并不支持全連接 full JOIN 關(guān)鍵字
          注意: 但是mysql 提供了 UNION 關(guān)鍵字.使用 UNION 可以間接實(shí)現(xiàn) full JOIN 功能

        #查詢(xún)?nèi)藛T和部門(mén)的所有數(shù)據(jù)   SELECT * FROM person LEFT JOIN dept ON person.did = dept.did UNION SELECT * FROM person RIGHT JOIN dept ON person.did = dept.did;

        示例

        mysql> SELECT * FROM person LEFT JOIN dept ON person.did = dept.did                 UNION              SELECT * FROM person RIGHT JOIN dept ON person.did = dept.did; +------+----------+------+------+--------+------+------+--------+ | id   | name     | age  | sex  | salary | did  | did  | dname  | +------+----------+------+------+--------+------+------+--------+ |    1 | alex     |   28 | 女   |  53000 |    1 |    1 | python | |    2 | wupeiqi  |   23 | 女   |  29000 |    1 |    1 | python | |    3 | egon     |   30 | 男   |  27000 |    1 |    1 | python | |    5 | jinxin   |   33 | 女   |  28888 |    1 |    1 | python | |    4 | oldboy   |   22 | 男   |      1 |    2 |    2 | linux  | |    7 | 令狐沖   |   22 | 男   |   6500 |    2 |    2 | linux  | |    6 | 張無(wú)忌   |   20 | 男   |   8000 |    3 |    3 | 明教   | |    8 | 東方不敗 |   23 | 女   |  18000 | NULL | NULL | NULL   | | NULL | NULL     | NULL | NULL | NULL   | NULL |    4 | 基督教 | +------+----------+------+------+--------+------+------+--------+ 9 rows in set

        注意: UNION 和 UNION ALL 的區(qū)別:UNION 會(huì)去掉重復(fù)的數(shù)據(jù),而 UNION ALL 則直接顯示結(jié)果

        復(fù)制條件多表查詢(xún)

        1、查詢(xún)出 教學(xué)部 年齡大于20歲,并且工資小于40000的員工,按工資倒序排列.(要求:分別使用多表聯(lián)合查詢(xún)和內(nèi)連接查詢(xún))

        示例

        #1.多表聯(lián)合查詢(xún)方式: select * from person p1,dept d2 where p1.did = d2.did       and d2.dname='python'      and  age>20      and salary <40000  ORDER BY salary DESC;  #2.內(nèi)連接查詢(xún)方式: SELECT * FROM person p1 INNER JOIN dept d2 ON p1.did= d2.did      and d2.dname='python'      and  age>20      and salary <40000  ORDER BY salary DESC;

        2、查詢(xún)每個(gè)部門(mén)中最高工資和最低工資是多少,顯示部門(mén)名稱(chēng)

        select MAX(salary),MIN(salary),dept.dname from          person LEFT JOIN dept             ON person.did = dept.did  GROUP BY person.did;

        子語(yǔ)句查詢(xún)

        子查詢(xún)(嵌套查詢(xún)): 查多次, 多個(gè)select

        注意: 第一次的查詢(xún)結(jié)果可以作為第二次的查詢(xún)的 條件 或者 表名 使用.

        子查詢(xún)中可以包含:IN、NOT IN、ANY、ALL、EXISTS 和 NOT EXISTS等關(guān)鍵字. 還可以包含比較運(yùn)算符:= 、 !=、> 、<等.

        1、作為表名使用
        select * from (select * from person) as 表名;

        ps:大家需要注意的是: 一條語(yǔ)句中可以有多個(gè)這樣的子查詢(xún),在執(zhí)行時(shí),最里層括號(hào)(sql語(yǔ)句) 具有優(yōu)先執(zhí)行權(quán).<br>注意: as 后面的表名稱(chēng)不能加引號(hào)('')

        2.求最大工資那個(gè)人的姓名和薪水
        1.求最大工資 select max(salary) from person; 2.求最大工資那個(gè)人叫什么 select name,salary from person where salary=53000;  合并 select name,salary from person where salary=(select max(salary) from person);
        3. 求工資高于所有人員平均工資的人員
        1.求平均工資 select avg(salary) from person;  2.工資大于平均工資的 人的姓名、工資 select name,salary from person where salary > 21298.625;  合并 select name,salary from person where salary >(select avg(salary) from person);

        推薦教程:mysql視頻教程

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
        主站蜘蛛池模板: 精品麻豆丝袜高跟鞋AV| 免费人成在线观看欧美精品| 日本精品不卡视频| 精品无码久久久久久久久久| 国精品午夜福利视频不卡麻豆| 88国产精品无码一区二区三区| 亚洲国产精品综合久久网络| 久久线看观看精品香蕉国产| 亚洲精品无码久久久久| 秋霞午夜鲁丝片午夜精品久| 亚洲线精品一区二区三区影音先锋| 亚洲国产成人久久精品影视| 精品国产日韩亚洲一区| 97久久国产亚洲精品超碰热| 亚洲AV无码成人精品区大在线| 日本久久久精品中文字幕| 久久亚洲国产成人精品无码区| 精品免费tv久久久久久久| 一夲道无码人妻精品一区二区| 国产91精品一区二区麻豆亚洲| 久久国产乱子伦免费精品| 欧美亚洲日本久久精品| 91精品成人免费国产片| 欧美亚洲综合免费精品高清在线观看| 国产精品亚洲精品观看不卡| 亚洲AV蜜桃永久无码精品| 99精品伊人久久久大香线蕉| 国产91精品在线观看| 日韩AV无码精品人妻系列| 中日韩产精品1卡二卡三卡| 亚洲国产精品毛片av不卡在线| 日韩蜜芽精品视频在线观看| 日韩亚洲精品福利| 九九精品在线视频| 久久精品国产只有精品66| 久久精品国产欧美日韩| 久久久久亚洲精品天堂久久久久久 | 精品免费视在线观看| 好属妞这里只有精品久久| 国产精品一级片| 一本大道久久a久久精品综合|