【数据库】SQL相关知识点总结1(数据库约束、三大范式、关系模型、聚合函数)

【数据库】SQL相关知识点总结1(数据库约束、三大范式、关系模型、聚合函数)

  • [1. 数据库约束](#1. 数据库约束)
  • [2. 三大范式](#2. 三大范式)
    • [2.1 第一范式](#2.1 第一范式)
    • [2.2 第二范式](#2.2 第二范式)
    • [2.3 第三范式](#2.3 第三范式)
  • [3. 关系模型](#3. 关系模型)
    • [3.1 一对一关系](#3.1 一对一关系)
    • [3.2 一对多关系](#3.2 一对多关系)
    • [3.3 多对多关系](#3.3 多对多关系)
  • [4. 聚合函数](#4. 聚合函数)

1. 数据库约束

  1. 非空设计 NOT NULL
sql 复制代码
CREATE TABLE `table`  (
  `id` bigint NOT NULL
);
  1. 唯一约束 UNIQUE
sql 复制代码
 CREATE TABLE `table`  (
  `id` bigint UNIQUE
);
  1. 主键约束 PRIMARY KEY
sql 复制代码
 CREATE TABLE `table`  (
  `id` bigint NOT NULL,
  PRIMARY KEY (`id`)
);
  1. 默认约束 DEFAULT
sql 复制代码
CREATE TABLE `table`  (
  `id` bigint NOT NULL,
  `age` bigint DEFAULT(18),
  PRIMARY KEY (`id`)
);
  1. 外键约束 FORIGN KEY
sql 复制代码
ALTER TABLE `table2`ADD INDEX(`name`);

CREATE TABLE `table1`  (
  `id` bigint NOT NULL,
  `age` bigint NULL,
  `name` varchar(255) NULL,
  PRIMARY KEY (`id`),
  CONSTRAINT `name` FOREIGN KEY (`name`) REFERENCES `table2` (`name`)
);

2. 三大范式

2.1 第一范式

定义:要求每个列表都不可再分
反例:

正例:

2.2 第二范式

定义:在满⾜第⼀范式的基础上,不存在⾮关键字段对任意候选键的部分函数依赖。存在于表中定义了复合主键的情况下。

反例:

正例:

2.3 第三范式

定义:在满⾜第⼆范式的基础上,不存在⾮关键字段,对任⼀候选键的传递依赖。

反例:课程名称与课程编号存在传递依赖,所以将重新建一个新表

正例:

3. 关系模型

3.1 一对一关系

3.2 一对多关系

3.3 多对多关系

多对多需要重新创建一个关联表

4. 聚合函数

以下表为例:

  1. COUNT(列) 统计结果的条数
sql 复制代码
SELECT COUNT(math) FROM `exam`;
  1. SUM(列) 求和
sql 复制代码
SELECT SUM(math) FROM `exam`;
  1. AVG(列) 求平均值
sql 复制代码
SELECT AVG(math) FROM `exam`;
  1. MIN(列) 求最小值
sql 复制代码
SELECT MIN(math) FROM `exam`;
  1. MAX(列) 求最大值
sql 复制代码
SELECT MAX(math) FROM `exam`;
相关推荐
一叶飘零_sweeeet5 分钟前
数据库连接池天花板之争:HikariCP 与 Druid 底层原理 + 高并发调优全拆解
数据库·hikaricp·数据库连接池·druid
GoodStudyAndDayDayUp6 分钟前
RUO-VUE-PRO权限关联sql
java·数据库·sql
@insist1237 分钟前
数据库系统工程师-SQL 数据定义语言(DDL)核心知识点与软考实战指南
数据库·oracle·软考·数据库系统工程师·软件水平考试
专利观察员8 分钟前
情报升维,决策降本:2026年专利数据库和专利检索实践的演进逻辑和实测
数据库
次旅行的库12 分钟前
【问渠哪得清如许-数据分析】学习笔记-下
数据库·笔记·sql·学习
万粉变现经纪人16 分钟前
如何解决 pip install cx_Oracle 报错 未找到 Oracle Instant Client 问题
数据库·python·mysql·oracle·pycharm·bug·pip
sw12138916 分钟前
使用Plotly创建交互式图表
jvm·数据库·python
2301_8101609519 分钟前
如何为开源Python项目做贡献?
jvm·数据库·python
SEO-狼术28 分钟前
Detect Aurora PostgreSQL Issues Faster
数据库·postgresql
2501_9454235434 分钟前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python