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

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

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

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

1. 数据库约束

  1. 非空设计 NOT NULL
CREATE TABLE `table`  (
  `id` bigint NOT NULL
);
  1. 唯一约束 UNIQUE
 CREATE TABLE `table`  (
  `id` bigint UNIQUE
);
  1. 主键约束 PRIMARY KEY
 CREATE TABLE `table`  (
  `id` bigint NOT NULL,
  PRIMARY KEY (`id`)
);
  1. 默认约束 DEFAULT
CREATE TABLE `table`  (
  `id` bigint NOT NULL,
  `age` bigint DEFAULT(18),
  PRIMARY KEY (`id`)
);
  1. 外键约束 FORIGN KEY
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(列) 统计结果的条数
SELECT COUNT(math) FROM `exam`;

在这里插入图片描述

  1. SUM(列) 求和
SELECT SUM(math) FROM `exam`;

在这里插入图片描述
5. AVG(列) 求平均值

SELECT AVG(math) FROM `exam`;

在这里插入图片描述

  1. MIN(列) 求最小值
SELECT MIN(math) FROM `exam`;

在这里插入图片描述

  1. MAX(列) 求最大值
SELECT MAX(math) FROM `exam`;

在这里插入图片描述


http://www.kler.cn/a/473064.html

相关文章:

  • WebSocket监听接口
  • Spring Boot教程之四十九:Spring Boot – MongoRepository 示例
  • 个人博客搭建(二)—Typora+PicGo+OSS
  • C++和Python中负数取余结果的区别
  • 【搜索】【推荐】大 PK
  • 计算机网络之---TCP/IP四层模型
  • 为什么页面无法正确显示?都有哪些HTML和CSS相关问题?
  • PHP语言的函数实现
  • svelte5中使用react组件
  • 跨界融合:人工智能与区块链如何重新定义数据安全?
  • MATLAB语言的软件工程
  • c#13新特性
  • 推动多语言语音科技迈向新高度:INTERSPEECH 2025 ML-SUPERB 2.0 挑战赛
  • JAVA常见问题解答
  • 【LeetCode Hot100 贪心算法】 买卖股票的最佳时机、跳跃游戏、划分字母区间
  • 【网络云SRE运维开发】2025第2周-每日【2025/01/08】小测-【第8章 STP生成树协议】理论和实操
  • 【Linux】shell脚本编程
  • 详解opencv resize之INTER_LINEAR和INTER_AREA
  • 用户注册模块(芒果头条项目进度4)
  • JVM三JVM虚拟机
  • 战地雷达通信系统中无人机与特种车辆智能组网及雷达通信一体化研究报告
  • UE蓝图节点备忘录
  • C++ 泛型编程:动态数据类模版类内定义、类外实现
  • 嵌入式系统 (2.嵌入式硬件系统基础)
  • 文献阅读分享:ChatGPT在推荐系统中的偏见研究
  • 使用Qt实现json数据的格式检测并序列化输出 Qt5.4.0环境