当前位置: 首页 > news >正文

用什么软件做网站最简单 最方便网店怎么开

用什么软件做网站最简单 最方便,网店怎么开,app设计尺寸规范,成全视频免费观看在线看游戏多表查询 内连接外连接自连接自连接查询联合查询 子查询 学习黑马MySQL课程,记录笔记,用于复习。 添加外键 alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);多表查询 select * from emp , dept where emp…

多表查询

    • 内连接
    • 外连接
    • 自连接
      • 自连接查询
      • 联合查询
    • 子查询

学习黑马MySQL课程,记录笔记,用于复习。

添加外键

alter table emp add constraint fk_emp_dept_id foreign key 
(dept_id) references dept(id);

多表查询

select * from emp , dept where emp.dept_id = dept.id;

笛卡尔积

select * from emp,dept;

内连接

1)隐式内连接

select 字段列表 from 表1 , 表2 where 条件 ... ;
select emp.name , dept.name from emp , dept where emp.dept_id = dept.id ;
#起别名 简化
select e.name,d.name from emp e , dept d where e.dept_id = d.id;

2)显式内连接

select 字段列表 from 表1  [ inner ] join 表2 on 条件 ... ;
select e.name, d.name from emp e inner join dept d on e.dept_id = d.id;

注意:
一旦为表起了别名,就不能再使用表名来指定对应的字段了
隐式:先做笛卡尔积,然后过滤;
显式:先匹配链接条件,再返回。性能和时间复杂度都是显式要好

外连接

1)左外连接——相当于左表的所有数据

select 字段列表 from 表1 left [ outer ] join 表2 on 条件 ... ;
select e.*, d.name from emp e left outer join dept d on e.dept_id = d.id;
# outer可以省略
select e.*, d.name from emp e left join dept d on e.dept_id = d.id;

2)右外连接——相当于右表的所有数据

select 字段列表 from 表1 right [ outer ] join 表2 on 条件 ... ;
select d.*, e.* from emp e right outer join dept d on e.dept_id = d.id;

自连接

自连接查询

自连接查询,就是把一张表连接查询多次。

select 字段列表 from 表A 别名A join 表A 别名B on 条件 ... ;
# 查询员工 及其 所属领导的名字
select a.name , b.name from emp a , emp b where a.managerid = b.id;
#  查询所有员工 emp 及其领导的名字 emp , 如果员工没有领导, 也需要查询出来
# 用左外连接
select a.name '员工', b.name '领导' from emp a left join emp b on a.managerid = b.id;

联合查询

联合查询,就是把多次查询的结果合并起来,形成一个新的查询结果集。

select 字段列表 from 表A ...
union [ all ]
select 字段列表 from 表B ...;
# 将薪资低于 5000 的员工 , 和 年龄大于 50 岁的员工全部查询出来.
select * from emp where salary < 5000
union 
select * from emp where age > 50;
  • 对于联合查询的多张表的列数必须保持一致,字段类型也需要保持一致。
  • union all 会将全部的数据直接合并在一起,union 会对合并之后的数据去重。

子查询

SQL语句中嵌套select语句,称为嵌套查询,又称子查询。

select * from t1 where columnl = ( select column1 from t2 );

根据子查询结果不同,分为:

子查询类型子查询结果
标量子查询单个值
列子查询一列
行子查询一行
表子查询多行多列

根据子查询位置不同,分为:

子查询类型
where 之后
from 之后
select 之后
标量子查询
-- 1. 查询 "销售部" 的所有员工信息
-- a. 查询 "销售部" 部门ID
select id from dept where name = '销售部';-- b. 根据销售部部门ID, 查询员工信息
select * from emp where dept_id = (select id from dept where name = '销售部');

列子查询

操作符描述
in在指定的集合范围之内,多选一
not in不在指定的集合范围之内
any子查询返回列表中,有任意一个满足即可
some与ANY等同,使用SOME的地方都可以使用ANY
all子查询返回列表的所有值都必须满足
select id from dept where name in('销售部','市场部');
select * from emp where dept_id in ( select id from dept where name in('销售部','市场部'));

行子查询
常用的操作符:= 、<> 、in 、not in。用法与行子查询类似。
表子查询
常用的操作符:in
查询入职日期是 “2006-01-01” 之后的员工信息 , 及其部门信息
1.入职日期是 “2006-01-01” 之后的员工信息

select * from emp where entrydate > '2006-01-01';

2.查询这部分员工, 对应的部门信息

select e.*, d.* from (select * from emp where entrydate > '2006-01-01') e left
join dept d on e.dept_id = d.id ;
http://www.shuangfujiaoyu.com/news/22916.html

相关文章:

  • python 做网站教程nba湖人最新新闻
  • 专科网站建设论文seo必备工具
  • 最专业的网站建设收费中国网站排名网官网
  • 成都网站建设收费明细百度开发平台
  • wordpress文章复制seo关键词优化方法
  • 做亚马逊外国网站需要语言好吗百度电话怎么转人工客服
  • 家政月嫂网站源码网站推广怎么推广
  • 现在还可以做夺宝网站软件开发公司推荐
  • 做淘宝设计能做网站吗seo实战培训中心
  • 广西建设厅网站资质查询个人如何加入百度推广
  • 做效果图挣钱网站云推广
  • 做网站客服维护电话怎么打个人介绍网页制作
  • 哪个网站可以做测试类如何百度推广
  • 合作做网站的总结和心得百度一下首页手机版
  • 怎么建免费企业官网站百度浏览器网址
  • 免费自适应网站模板网站免费搭建平台
  • 广东佛山网站建设免费的网络推广渠道
  • 怎么办个人网站狼雨的seo教程
  • 自己做的网站放在服务器哪里墨子学院seo
  • 做橡胶的网站苏州整站优化
  • 网站联系方式要素谷歌推广平台
  • 网站开发写好了怎么发布今日新闻热点大事件
  • 成都网站推广创新互联谷粉搜索谷歌搜索
  • 一手项目对接app平台优化二十条
  • 设计网站项目描述哪里可以免费推广广告
  • 本站由 今科云平台网站建设技术开发怎么建自己的网站?
  • 手机端网站ui做多少像素一个网站如何推广
  • 做软文的网站国外免费域名
  • 三角镇建网站公司职业培训学校
  • 哪个网站可以做申论真题网络营销是什么工作