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

中国信誉建设网站wordpress 自动博客

中国信誉建设网站,wordpress 自动博客,品牌注册号,建盏周世义个人简介🏝️专栏:Mysql_猫咪-9527的博客-CSDN博客 🌅主页:猫咪-9527-CSDN博客 “欲穷千里目,更上一层楼。会当凌绝顶,一览众山小。” 目录 1、表连接的核心概念 1.1 为什么需要表连接? 2、内连接&a…

🏝️专栏:Mysql_猫咪-9527的博客-CSDN博客
🌅主页:猫咪-9527-CSDN博客 

“欲穷千里目,更上一层楼。会当凌绝顶,一览众山小。”

目录

1、表连接的核心概念

1.1 为什么需要表连接?

2、内连接(INNER JOIN)

2.1 核心概念

2.2 案例:

3、外连接(OUTER JOIN)

3.1 左外连接(LEFT JOIN)

核心概念

案例:查询所有雇员及工资

3.2 右外连接(RIGHT JOIN)

核心概念

案例:查询所有工资,即使无对应雇员

3.3 左外与右外的等价性

4、注意事项

4.1 ON与WHERE子句的区别

4.2 NULL值的处理


1、表连接的核心概念

1.1 为什么需要表连接?

  • 问题:两个表的数据需要关联查询(如学生表和成绩表)
  • 笛卡尔积:未指定条件时,两个表的所有记录两两组合(效率低下,结果混乱)
  • 解决方案:通过连接条件筛选有效组合

2、内连接(INNER JOIN)

2.1 核心概念

  • 定义:仅返回两表中满足连接条件的记录

        内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我们前面学习的查询都是内连接,也是在开发过程中使用的最多的连接查询。

  • 语法
    select 字段 from 表1 inner join 表2 on 表1.id = 表2.id [and 其他筛选条件];
    
  • 等价写法WHERE子句隐式内连接

    SELECT 字段 FROM 表1, 表2 WHERE 表1.id = 表2.id [and 其他筛选条件];
    

2.2 案例:

查询员工及其部门名称

两者写法不同但是效果一致

方法一:

---隐式内连接写法
select *from emp,dept where emp.deptno=dept.deptno;

 方法二:

---标准内连接写法
select *from dept inner join emp on emp.deptno=dept.deptno;


3、外连接(OUTER JOIN)

外连接分为左外连接和右外连接

3.1 左外连接(LEFT JOIN)

核心概念
  • 保留规则左表(第一个表)的所有记录,右表无匹配时用NULL填充
  • 语法
    select 字段 from 表1 left join 表2 on 链接条件 [and 其他筛选条件];
    
案例:查询所有雇员及工资
-- 创建表
CREATE TABLE employees (emp_id INT, emp_name VARCHAR(30));
INSERT INTO employees VALUES (1, 'Alice'), 
(2, 'Bob'), (3, 'Charlie'), (4, 'David');CREATE TABLE salaries (emp_id INT, salary INT);
INSERT INTO salaries VALUES (1, 5000), (2, 6000), (5, 7000);-- 左外连接查询
select *from employees s1 left join salaries s2 on s1.emp_id=s2.emp_id;

结果


3.2 右外连接(RIGHT JOIN)

核心概念
  • 保留规则右表(第二个表)的所有记录,左表无匹配时用NULL填充
  • 语法
    select 字段 from 左表 right join 右表 on 链接条件 [and 其他筛选条件];
    
案例:查询所有工资,即使无对应雇员
select *from employees s1 right join salaries s2 
on s1.emp_id=s2.emp_id;

结果


3.3 左外与右外的等价性

-- 左外连接(保留左表)
SELECT * FROM A LEFT JOIN B ON A.id = B.id;-- 等价于右外连接(保留右表)
SELECT * FROM B RIGHT JOIN A ON A.id = B.id;

建议:优先使用左外连接,逻辑更直观。 


4、注意事项

4.1 ON与WHERE子句的区别

  • ON:用于指定连接条件,影响匹配逻辑。
  • on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。

  • WHERE:用于过滤已连接后的结果,会过滤掉外连接中的NULL值。
  • where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉,on后的条件用来生成左右表关联的临时表,where后的条件对临时表中的记录进行过滤。


4.2 NULL值的处理

  • 外连接结果中的NULL表示无匹配记录,需在业务逻辑中处理(如显示“无成绩”)。

http://www.dtcms.com/wzjs/788250.html

相关文章:

  • 凌源网站建设网站开发基础知识试题
  • 建设网站和公告号的意义博瑞微传媒建站快车
  • 沧州北京网站建设织梦网站建设考试
  • wordpress 别名排序龙岗网站优化培训
  • 如何开发网站建设业务邯郸旅游景点
  • 谷歌网站推广排名工具网站建设要注意那些问题
  • jz做网站做个商城网站怎么做便宜吗
  • 网站架构模板wordpress 全局音乐
  • 上海做网站站优云一一十七北京服装设计公司前十名
  • 安徽seo网站网站内网页标题对百度排名
  • 网站忘记密码功能成都网站建设桔子科技
  • 自建网站平台有哪些wordpress美化登录
  • 郑州龙华小学网站建设WordPress博客Modown模板
  • 网站建设合同书wordpress国内支付
  • 网站建设费用贵不贵做企业网站有效果吗
  • ECMS做的网站做死活题网站
  • 杭州网站程序开发公司网页设计实训结论
  • 网站单页面怎么做的汝阳网站建设
  • 做ppt常用的网站有哪些东莞网站设计建设公司
  • 禹州市门户网站建设华为最新消息
  • 网站空间免泰安市人才交流服务中心
  • 盐城公司网站建设做网站最基础需要什么条件
  • 贵阳网站推广¥做下拉去118cr五大建设内容
  • 国外网站开发技术福州网站建设网络公司
  • 网站制作公司兴田德润i在哪里公司网站建设要求书
  • 杭州自助建站河北建设厅网站开通账号
  • 网页设计与网站建设西方设计网站
  • 网站建设工程师职责在线一键生成网页
  • 在门户网站做产品seo广州电商小程序开发
  • 域名做网站北海建设网站