MySQL基础

数据库的三大范式是什么?

  • 第一范式(1NF):要求数据库表的每一列都是不可分割的原子数据项。

  • 第二范式(2NF):在第一范式的基础上,且不存在部分依赖。

    • 非主属性必须完全依赖主属性
  • 第三范式(3NF):在第二范式的基础上,且不存在传递依赖。

    • 非主属性与非主属性之间不能有依赖关系,非主属性必须直接依赖主属性

MySQL是怎么联表查询?

数据库联表查询有四种:

  1. 内连接(innter join)
  2. 左外连接(left join)
  3. 右外连接(right join)
  4. 全外连接(full join)

内连接:查询的是两个表的交集,即两张表都有的数据(通常以数据量小的表作为驱动表)

SQL代码展示:

MySQL 复制代码
    # FROM 两表 WHERE 连接
    SELECT * FROM A表 , B表 WHERE A表.id = B表.id;

    # JOIN ON 连接
    SELECT * FROM A表  JOIN B表 
    ON A表.id = B表.id;

    # INNER JOIN ON 连接
    SELECT * FROM A表 INNER JOIN B表 
    ON A表.id = B表.id;

    # 多JOIN ON 连接
    SELECT * FROM A表 
    INNER JOIN B表 
    	ON A表.id = B表.id
    INNER JOIN C表 
    	ON B表.id = C表.id;

左外连接 :会返回左表中所有的记录。如果右表中没有匹配的记录,则右表字段使用 null 填充

SQL代码展示:

MySQL 复制代码
# LEFT JOIN ON 连接。 
SELECT * FROM A表 LEFT JOIN B表 
ON A表.id = B表.id;

右外连接 :右连接会返回右表中的所有记录。如果左表中没有匹配的记录,则左表字段使用 NULL 填充

SQL代码展示:

MySQL 复制代码
# RIGHT JOIN ON 连接
SELECT * FROM A表 RIGHT JOIN B表 
ON A表.id = B表.id;

全外连接:返回两个表中所有行,包括非匹配行。在MySQL中,FULL JOIN 需要使用 UNION 来实现,因为 MySQL 不直接支持 FULL JOIN


SQL代码展示:

MySQL 复制代码
SELECT * FROM A表 LEFT JOIN B表 ON A表.id = B表.id
UNION
SELECT * FROM A表 RIGHT JOIN B表 ON A表.id = B表.id
相关推荐
一 乐27 分钟前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
码事漫谈2 小时前
Protocol Buffers 编码原理深度解析
后端
码事漫谈2 小时前
gRPC源码剖析:高性能RPC的实现原理与工程实践
后端
踏浪无痕3 小时前
AI 时代架构师如何有效成长?
人工智能·后端·架构
程序员小假3 小时前
我们来说一下无锁队列 Disruptor 的原理
java·后端
武子康5 小时前
大数据-209 深度理解逻辑回归(Logistic Regression)与梯度下降优化算法
大数据·后端·机器学习
maozexijr5 小时前
Rabbit MQ中@Exchange(durable = “true“) 和 @Queue(durable = “true“) 有什么区别
开发语言·后端·ruby
源码获取_wx:Fegn08955 小时前
基于 vue智慧养老院系统
开发语言·前端·javascript·vue.js·spring boot·后端·课程设计
独断万古他化5 小时前
【Spring 核心: IoC&DI】从原理到注解使用、注入方式全攻略
java·后端·spring·java-ee
毕设源码_郑学姐5 小时前
计算机毕业设计springboot基于HTML5的酒店预订管理系统 基于Spring Boot框架的HTML5酒店预订管理平台设计与实现 HTML5与Spring Boot技术驱动的酒店预订管理系统开
spring boot·后端·课程设计