数据库基础

一、基本概念

  1. 数据库(DB):长期存储在计算机内、有组织、可共享的数据集合。

  2. 数据库管理系统(DBMS):管理数据库的软件,如 MySQL、Oracle、SQL Server、PostgreSQL。

  3. 数据库系统(DBS):DB + DBMS + 应用程序 + 管理员 + 用户。

  4. 数据模型三要素:数据结构、数据操作、完整性约束。

二、常见数据模型

• 层次模型:树形结构,一对多

• 网状模型:图结构,多对多

• 关系模型:用二维表表示(主流)

三、关系数据库核心

  1. 关系 = 表

◦ 行 = 元组 = 记录

◦ 列 = 属性 = 字段

  1. 键(关键字)

◦ 超键:能唯一标识元组的属性集

◦ 候选键:最小超键,无多余属性

◦ 主键(Primary Key):选中的候选键,唯一非空

◦ 外键(Foreign Key):引用另一表主键,用于关联

  1. 三大完整性

◦ 实体完整性:主键非空唯一

◦ 参照完整性:外键要么为空,要么是对应主键值

◦ 用户自定义完整性:如取值范围、唯一、非空等

四、SQL 基础

  1. 分类

• DDL:数据定义(CREATE、ALTER、DROP)

• DML:数据操作(INSERT、UPDATE、DELETE、SELECT)

• DCL:数据控制(GRANT、REVOKE)

• TCL:事务控制(COMMIT、ROLLBACK)

  1. 常用语句

• 建表:CREATE TABLE 表名(字段 类型 约束);

• 查询:SELECT * FROM 表名 WHERE 条件 GROUP BY 分组 HAVING 筛选 ORDER BY 排序;

• 插入:INSERT INTO 表名(字段) VALUES(值);

• 更新:UPDATE 表名 SET 字段=值 WHERE 条件;

• 删除:DELETE FROM 表名 WHERE 条件;

  1. 常用函数

• 聚合:COUNT、SUM、AVG、MAX、MIN

• 分组:GROUP BY

• 排序:ORDER BY ASC/DESC

五、三大范式(1NF、2NF、3NF)

  1. 1NF:列不可再分,原子性

  2. 2NF:满足1NF,非主属性完全依赖主键(消除部分依赖)

  3. 3NF:满足2NF,非主属性不传递依赖主键(消除传递依赖)

六、索引

• 作用:加快查询,减慢增删改

• 类型:主键索引、唯一索引、普通索引、复合索引

• 原则:经常查询、选择性高的字段建索引;频繁修改、重复值多的少建

七、事务(Transaction)

四大特性 ACID:

• A原子性:要么全做,要么全不做

• C一致性:执行前后数据合法

• I隔离性:事务间互不干扰

• D持久性:提交后永久生效

八、并发问题 & 隔离级别

• 问题:脏读、不可重复读、幻读

• 隔离级别(由低到高):

读未提交 → 读已提交 → 可重复读 → 串行化

九、连接查询

• INNER JOIN:内连接,两边都匹配

• LEFT JOIN:左连接,左表全显示

• RIGHT JOIN:右连接,右表全显示

• FULL JOIN:全连接(部分数据库支持)

十、视图 & 存储过程

• 视图:虚拟表,简化查询,控制权限

• 存储过程:预编译 SQL 集合,提高效率

相关推荐
会编程的土豆几秒前
Gin 框架第一课:从 0 搞懂 Gin 最基础的路由
数据库·sql·gin·goland
雨浓YN2 分钟前
GKTGD 工业监控系统-02MySQL 数据库技术文档(类库:NET8_SQLData)
数据库·wpf
dFObBIMmai2 分钟前
JavaScript中对象生命周期与垃圾回收的引用关系
jvm·数据库·python
2401_824697662 分钟前
Go语言怎么格式化时间_Go语言time.Format教程【详解】
jvm·数据库·python
2303_821287383 分钟前
HTML函数在低背光键盘上编写困难吗_输入设备舒适度说明【介绍】
jvm·数据库·python
爱喝水的鱼丶3 分钟前
SAP-ABAP:ABAP Development Tools(ADT)安装配置学习分享教程(四篇连载)第四篇:ADT连接故障排查与环境迁移教程
运维·开发语言·数据库·学习·sap·abap
2301_783848654 分钟前
防范SQL注入的SQL编码规范_禁用动态拼接字符串语句
jvm·数据库·python
weixin_444012935 分钟前
Angular 表单中基于下拉选择动态启用字段必填校验的完整实现
jvm·数据库·python
zjy277776 分钟前
CSS解决浮动元素导致的布局闪烁_稳定容器布局高度
jvm·数据库·python
2501_901006476 分钟前
MySQL主从复制过程中怎么增加从库_利用mysqldump快速扩容从库
jvm·数据库·python