最新公告
  • 欢迎您光临旗鱼小站,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入我们
  • MySQL如何实现多表查询?MySQL多表查询的语句

    本篇文章给大家带来的内容是介绍MySQL如何实现多表查询?MySQL多表查询的语句。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

    创建表

    # 创建表 create table department(id int,name varchar(20)); create table employee1( id int primary key auto_increment, name varchar(20), sex enum('male','female') not null default 'male', age int, dep_id int ); # 插入数据 insert into department values(200,'技术'),(201,'人力资源'),(202,'销售'),(203,'运营');  insert into employee1(name,sex,age,dep_id) values('egon','male',18,200),('alex','female',48,201),('tom','male',38,201),('yuanhao','female',28,202),('lidawei','male',18,200),('jinkezhou','female',18,204);  # 查看表 mysql> select * from employee1; +----+-----------+--------+------+--------+ | id | name      | sex    | age  | dep_id | +----+-----------+--------+------+--------+ |  1 | egon      | male   |   18 |    200 | |  2 | alex      | female |   48 |    201 | |  3 | tom       | male   |   38 |    201 | |  4 | yuanhao   | female |   28 |    202 | |  5 | lidawei   | male   |   18 |    200 | |  6 | jinkezhou | female |   18 |    204 | +----+-----------+--------+------+--------+ 6 rows in set (0.00 sec) mysql> select * from department; +------+--------------+ | id   | name         | +------+--------------+ |  200 | 技术       | |  201 | 人力资源   | |  202 | 销售       | |  203 | 运营       | +------+--------------+ 4 rows in set (0.00 sec)

    多表连接查询

    交叉连接

    交叉连接:不适用任何匹配条件。生成笛卡尔积

    mysql> select * from employee1 ,department;

    内连接

    内连接:找两张表共有的部分,相当于利用条件从笛卡尔积结果中筛选出了正确的结果。(只连接匹配的行)

    # 找两张表共有的部分,相当于利用条件从笛卡尔积结果中筛选出了正确的结果 #department没有204这个部门,因而employee表中关于204这条员工信息没有匹配出来 mysql> select * from employee1,department where employee1.dep_id=department.id;  #上面用where表示的可以用下面的内连接表示,建议使用下面的那种方法 mysql> select * from employee1 inner join department on employee1.dep_id=department.id;  # 也可以这样表示哈 mysql> select employee1.id,employee1.name,employee1.age,employee1.sex,department.name from employee1,department where employee1.dep_id=department.id;

    左连接left

    优先显示左表全部记录。

    #左链接:在按照on的条件取到两张表共同部分的基础上,保留左表的记录 mysql> select * from employee1 left join department on department.id=employee1.dep_id;  mysql> select * from department left join  employee1 on department.id=employee1.dep_id;

    右连接right

    优先显示右表全部记录。

    #右链接:在按照on的条件取到两张表共同部分的基础上,保留右表的记录 mysql> select * from employee1 right join department on department.id=employee1.dep_id; mysql> select * from department right join employee1 on department.id=employee1.dep_id;

    全部连接join

    mysql> select * from department full join employee1;

    符合条件多表查询

    示例1:以内连接的方式查询employee和department表,并且employee表中的age字段值必须大于25,
    即找出公司所有部门中年龄大于25岁的员工

    mysql> select * from employee1 inner join department on employee1.dep_id=department.id and age>25;

    示例2:以内连接的方式查询employee和department表,并且以age字段的升序方式显示

    mysql> select * from employee1 inner join department on employee1.dep_id=department.id and age>25 and age>25 order by age asc;

    子查询

    #1:子查询是将一个查询语句嵌套在另一个查询语句中。 #2:内层查询语句的查询结果,可以为外层查询语句提供查询条件。 #3:子查询中可以包含:IN、NOT IN、ANY、ALL、EXISTS 和 NOT EXISTS等关键字 #4:还可以包含比较运算符:= 、 !=、> 、<等

    示例:

    # 查询平均年龄在25岁以上的部门名 mysql> select name from department where id in ( select dep_id from employee1 group by dep_id having avg(age) > 25 );  # 查看技术部员工姓名 mysql> select name from employee1 where dep_id = (select id from department where name='技术');  # 查看小于2人的部门名 mysql> select name from department where id in (select dep_id from employee1 group by dep_id having count(id) < 2) union select name from department where id not in (select distinct dep_id from employee1); # 提取空部门                               #有人的部门 mysql> select * from department where id not in (select distinct dep_id from employee1);
    旗鱼小站.我们不生产资源,我们只是大资源的搬运工
    旗鱼小站 » MySQL如何实现多表查询?MySQL多表查询的语句

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。

    发表评论

    售后服务:

    • 售后服务范围 1、商业模板使用范围内问题免费咨询
      2、源码安装、模板安装(一般 ¥50-300)服务答疑仅限SVIP用户
      3、单价超过200元的模板免费一次安装,需提供服务器信息。
      付费增值服务 1、提供dedecms模板、WordPress主题、discuz模板优化等服务请详询在线客服
      2、承接 WordPress、DedeCMS、Discuz 等系统建站、仿站、开发、定制等服务
      3、服务器环境配置(一般 ¥50-300)
      4、网站中毒处理(需额外付费,500元/次/质保三个月)
      售后服务时间 周一至周日(法定节假日除外) 9:00-23:00
      免责声明 本站所提供的模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: 1262500034@qq.com),我们会及时删除,给您带来的不便,我们深表歉意!

    Hi, 如果你对这款模板有疑问,可以跟我联系哦!

    联系作者
    • 1489会员总数(位)
    • 2093资源总数(个)
    • 6本周发布(个)
    • 0 今日发布(个)
    • 290稳定运行(天)

    提供最优质的资源集合

    免费资源 精品源码