数据库基础:概念、原理与实战示例

在当今信息时代,数据已经成为企业和个人的核心资产。无论是社交媒体、电子商务、金融交易,还是物联网设备,几乎所有的现代应用都依赖于高效的数据存储和管理。数据库(Database)作为数据管理的核心技术,帮助用户存储、检索、更新和分析数据。本文将详细介绍数据库的基本概念、类型、核心组件、操作语言,并结合实际示例,帮助读者深入理解数据库的工作原理和应用。

1. 什么是数据库?

1.1 数据与数据库

  • 数据(Data):指原始的事实或信息,如数字、文本、图像等。例如,一个学生的姓名、年龄、成绩都是数据。

  • 数据库(Database, DB):指有组织的数据集合,便于存储、管理和检索。例如,学校的学生信息管理系统就是一个数据库。

1.2 数据库管理系统(DBMS)

数据库管理系统(Database Management System, DBMS)是用于管理数据库的软件系统,如:

  • 关系型数据库:MySQL、PostgreSQL、Oracle、SQL Server

  • 非关系型数据库:MongoDB、Redis、Cassandra

DBMS 的主要功能包括:

  • 数据定义(创建、修改表结构)

  • 数据操作(增删改查)

  • 数据安全(权限控制)

  • 事务管理(保证数据一致性)

1.3 数据库系统(DBS)

数据库系统(Database System, DBS)包括:

  • 数据库(DB)

  • 数据库管理系统(DBMS)

  • 应用程序(如网站、APP)

  • 用户(管理员、开发者、普通用户)

2. 数据库模型

数据库模型决定了数据如何存储和组织,主要分为 关系型数据库(RDBMS) 和 非关系型数据库(NoSQL)

2.1 关系型数据库(RDBMS)

关系型数据库以 表(Table) 的形式存储数据,表由 行(Row) 和 列(Column) 组成。

示例:学生信息表(Students)
StudentID (主键)NameAgeMajor
1张三20计算机
2李四21数学
3王五19物理
  • 表(Table):存储特定类型的数据(如学生信息)。

  • 行(Row)/ 元组(Tuple):代表一条记录(如一个学生的数据)。

  • 列(Column)/ 属性(Attribute):代表数据的某个特征(如姓名、年龄)。

  • 主键(Primary Key):唯一标识一行(如 StudentID)。

  • 外键(Foreign Key):用于关联不同表(如 StudentID 可以关联到成绩表)。

SQL 示例(关系型数据库操作)
-- 创建表
CREATE TABLE Students (StudentID INT PRIMARY KEY,Name VARCHAR(50),Age INT,Major VARCHAR(50)
);-- 插入数据
INSERT INTO Students (StudentID, Name, Age, Major)
VALUES (1, '张三', 20, '计算机');-- 查询数据
SELECT * FROM Students WHERE Age > 19;-- 更新数据
UPDATE Students SET Age = 22 WHERE StudentID = 1;-- 删除数据
DELETE FROM Students WHERE StudentID = 3;

2.2 非关系型数据库(NoSQL)

NoSQL 数据库适用于非结构化或半结构化数据,主要类型包括:

  1. 键值存储(Key-Value):如 Redis

  2. 文档存储(Document):如 MongoDB

  3. 列存储(Column-Family):如 Cassandra

  4. 图数据库(Graph):如 Neo4j

示例:MongoDB(文档存储)
// 学生文档(JSON 格式)
{"_id": 1,"name": "张三","age": 20,"major": "计算机","courses": ["数据结构", "算法"]
}

MongoDB 操作示例

// 插入数据
db.students.insertOne({_id: 1,name: "张三",age: 20,major: "计算机"
});// 查询数据
db.students.find({ age: { $gt: 19 } });// 更新数据
db.students.updateOne({ _id: 1 },{ $set: { age: 22 } }
);// 删除数据
db.students.deleteOne({ _id: 3 });

3. 数据库的核心组件

3.1 表(Table)

表是关系型数据库的基本存储单位,例如:

  • Students 表存储学生信息

  • Courses 表存储课程信息

3.2 主键(Primary Key)

唯一标识表中的每一行,如 StudentID

3.3 外键(Foreign Key)

用于建立表之间的关系,例如:

  • Students 表有 StudentID

  • Scores 表引用 StudentID 关联学生和成绩

示例:外键关联
-- 创建成绩表(Scores)
CREATE TABLE Scores (ScoreID INT PRIMARY KEY,StudentID INT,Course VARCHAR(50),Score INT,FOREIGN KEY (StudentID) REFERENCES Students(StudentID)
);

3.4 索引(Index)

提高查询速度,例如:

-- 在 Students 表的 Name 列上创建索引
CREATE INDEX idx_name ON Students(Name);

3.5 视图(View)

虚拟表,基于 SQL 查询结果:

-- 创建视图:显示年龄大于 19 的学生
CREATE VIEW AdultStudents AS
SELECT * FROM Students WHERE Age > 19;

4. 数据库操作语言(SQL)

4.1 数据定义语言(DDL)

用于定义数据库结构:

CREATE TABLE ...  -- 创建表
ALTER TABLE ...   -- 修改表
DROP TABLE ...    -- 删除表

4.2 数据操作语言(DML)

用于操作数据:

INSERT INTO ...   -- 插入数据
SELECT ...        -- 查询数据
UPDATE ...        -- 更新数据
DELETE FROM ...   -- 删除数据

4.3 数据控制语言(DCL)

用于权限管理:

GRANT SELECT ON Students TO user1;  -- 授权
REVOKE SELECT ON Students FROM user1; -- 撤销权限

5. 数据库特性

5.1 ACID 原则

  • 原子性(Atomicity):事务要么全部成功,要么全部失败(如银行转账)。

  • 一致性(Consistency):事务执行前后数据保持一致。

  • 隔离性(Isolation):多个事务并发执行时互不干扰。

  • 持久性(Durability):事务提交后,数据永久保存。

示例:银行转账事务
BEGIN TRANSACTION;UPDATE Accounts SET Balance = Balance - 100 WHERE AccountID = 1;UPDATE Accounts SET Balance = Balance + 100 WHERE AccountID = 2;
COMMIT;

5.2 事务(Transaction)

一组 SQL 操作,作为一个整体执行:

START TRANSACTION;INSERT INTO Orders (OrderID, CustomerID) VALUES (101, 1);INSERT INTO OrderDetails (OrderID, ProductID) VALUES (101, 1001);
COMMIT;

5.3 规范化(Normalization)

减少数据冗余,提高数据一致性:

  • 第一范式(1NF):每个列不可再分(如 Address 不能包含 City 和 Street)。

  • 第二范式(2NF):满足 1NF,并且非主键列完全依赖主键。

  • 第三范式(3NF):满足 2NF,并且非主键列之间没有传递依赖。

6. 数据库应用场景

  1. 关系型数据库:适用于结构化数据,如银行系统、ERP。

  2. NoSQL 数据库:适用于大数据、实时分析,如社交网络、IoT。

  3. 内存数据库(Redis):适用于缓存、会话管理。

  4. 图数据库(Neo4j):适用于推荐系统、社交网络分析。

结论

数据库是现代信息系统的核心,理解其基本概念和操作至关重要。本文介绍了:

  • 数据库的基本概念(DB、DBMS、DBS)

  • 关系型数据库 vs. NoSQL

  • 核心组件(表、主键、外键、索引)

  • SQL 语言(DDL、DML、DCL)

  • 数据库特性(ACID、事务、规范化)

无论是开发网站、APP,还是进行数据分析,掌握数据库知识都能让你更高效地管理和利用数据。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/80861.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端-HTML基本概念

目录 什么是HTML 常用的浏览器引擎是什么? 常见的HTML实体字符 HTML注释 HTML语义化是什么?为什么要语义化?一定要语义化吗? 连续空格如何渲染? 声明文档类型 哪些字符集编码支持简体中文? 如何解…

Linux进程信号处理(26)

文章目录 前言一、信号的处理时机处理情况“合适”的时机 二、用户态与内核态概念重谈进程地址空间信号的处理过程 三、信号的捕捉内核如何实现信号的捕捉?sigaction 四、信号部分小结五、可重入函数六、volatile七、SIGCHLD 信号总结 前言 这篇就是我们关于信号的最…

C++ 字符格式化输出

文章目录 一、简介二、实现代码三、实现效果 一、简介 这里使用std标准库简单实现一个字符格式化输出&#xff0c;方便后续的使用&#xff0c;它有点类似Qt中的QString操作。 二、实现代码 FMTString.hpp #pragma once#include <cmath> #include <cstdio> #include…

python高级特性

json.dumps({a:1,n:2}) #Python 字典类型转换为 JSON 对象。相当于jsonify data2 json.loads(json_str)#将 JSON 对象转换为 Python 字典 异步编程&#xff1a;在异步编程中&#xff0c;程序可以启动一个长时间运行的任务&#xff0c;然后继续执行其他任务&#xff0c;而无需等…

ubuntu24离线安装docker

一、确认ubuntu版本 root@dockerserver:/etc/pam.d# lsb_release -a No LSB modules are available. Distributor ID: Ubuntu Description: Ubuntu 24.04.2 LTS Release: 24.04 Codename: noble 根据codename确认。 docker官方网址下载 https://download.docker.com/linux/…

索尼(sony)摄像机格式化后mp4的恢复方法

索尼(sony)的Alpha 7 Ⅳ系列绝对称的上是索尼的“全画幅标杆机型”&#xff0c;A7M4配备了3300万像素的CMOS&#xff0c;以及全新研发的全画幅背照式Exmor R™CMOS影像传感器&#xff0c;搭载BIONZ XR™影像处理器&#xff0c;与旗舰微单™Alpha 1如出一辙。下面我们来看看A7M4…

2025最新出版 Microsoft Project由入门到精通(七)

目录 优化资源——在资源使用状况视图中查看资源的负荷情况 在资源图表中查看资源的负荷情况 优化资源——资源出现冲突时的原因及处理办法 资源过度分类的处理解决办法 首先检查任务工时的合理性并调整 增加资源供给 回到资源工作表中双击对应的过度分配资源 替换资…

最短路与拓扑(1)

1、找最长良序字符串 #include<bits/stdc.h> using namespace std; const int N105; int dis[N]; int vis[N]; int edge[N][N]; int n,m; int vnum;void dij(int u, int v) {// 初始化距离数组和访问标记for(int i0; i<vnum; i) {vis[i] 0;dis[i] edge[u][i];}// D…

降低60.6%碰撞率!复旦大学地平线CorDriver:首次引入「走廊」增强端到端自动驾驶安全性

导读 复旦大学&地平线新作-CorDriver: 首次通过引入"走廊"作为中间表征&#xff0c;揭开一个新的范式。预测的走廊作为约束条件整合到轨迹优化过程中。通过扩展优化的可微分性&#xff0c;使优化后的轨迹能无缝地在端到端学习框架中训练&#xff0c;从而提高安全…

CSS flex:1

在 CSS 中&#xff0c;flex: 1 是一个用于弹性布局&#xff08;Flexbox&#xff09;的简写属性&#xff0c;主要用于控制 flex 项目&#xff08;子元素&#xff09;如何分配父容器的剩余空间。以下是其核心作用和用法&#xff1a; 核心作用 等分剩余空间&#xff1a;让 flex …

1.6 关于static和final的修饰符

一.static static是静态修饰符&#xff0c;用于修饰类成员&#xff08;变量&#xff0c;方法&#xff0c;代码块&#xff09; 被修饰的类成员属于类&#xff0c;不必生成示例&#xff0c;即可直接调用属性或者方法。 关于代码块&#xff0c;被static修饰的代码块是静态代码块…

数据结构—(链表,栈,队列,树)

本文章写的比较乱&#xff0c;属于是缝合怪&#xff0c;很多细节没处理&#xff0c;显得粗糙&#xff0c;日后完善&#xff0c;今天赶时间了。 1. 红黑树的修复篇章 2. 红黑树的代码理解&#xff08;部分写道注释之中了&#xff09; 3. 队列与栈的代码 4. 重要是理解物理逻辑&a…

每日Prompt:发光线条解剖图

提示词 一幅数字插画&#xff0c;描绘了一个 [SUBJECT]&#xff0c;其结构由一组发光、干净且纯净的蓝色线条勾勒而成。画面设定在深色背景之上&#xff0c;以突出 [SUBJECT] 的形态与特征。某个特定部位&#xff0c;如 [PART]&#xff0c;通过红色光晕加以强调&#xff0c;以…

【时时三省】(C语言基础)使用字符串处理函数

山不在高&#xff0c;有仙则名。水不在深&#xff0c;有龙则灵。 ----CSDN 时时三省 在C函数库中提供了一些用来专门处理字符串的函数&#xff0c;使用方便。几乎所有版本的C语言编译系统都提供这些函数。下面介绍几种常用的函数。 ①puts函数 输出字符串的函数 其一般形式…

构建可信数据空间需要突破技术、规则和生态三大关键

构建可信数据空间需要突破技术、规则和生态三大关键&#xff1a;技术上要解决"可用不可见"的隐私计算难题&#xff0c;规则上要建立动态确权和跨境流动的治理框架&#xff0c;生态上要形成多方协同的标准体系。他强调&#xff0c;只有实现技术可控、规则可信、生态协…

模板的使用

模板 模板的概念&#xff1a;模板就是建立一个通用的模具&#xff0c;大大提高复用性 c中模板机制分为两类 函数模板 建立一个通用函数&#xff0c;其函数返回值类型和形参类型可以不具体定制&#xff0c;用一个虚拟的类型来代表 template<typename T> //template 声…

YOLOv1:开启实时目标检测的新篇章

YOLOv1&#xff1a;开启实时目标检测的新篇章 在深度学习目标检测领域&#xff0c;YOLO&#xff08;You Only Look Once&#xff09;系列算法无疑占据着重要地位。其中&#xff0c;YOLOv1作为开山之作&#xff0c;以其独特的设计理念和高效的检测速度&#xff0c;为后续的目标…

vim中的查找

在 Vim 中&#xff0c;使用 n 键可以按正向&#xff08;向下&#xff09;继续查找下一个匹配项。若要反向&#xff08;向上&#xff09;查找&#xff0c;可以使用以下方法&#xff1a; 1. 使用 N 键反向查找 在查找命令&#xff08;如 /keyword&#xff09;后&#xff0c;按下…

卡尔曼滤波通俗理解

卡尔曼滤波器的目的与意义何在&#xff1f; - 陈不陈的回答 - 知乎 https://www.zhihu.com/question/41351736/answer/3057034500 这是一个比较通俗易懂的例子&#xff0c;读完之后可以对卡尔曼滤波怎么使用有比较直观的理解。 &#x1f9e0; 一、卡尔曼滤波是什么&#xff1f;…

对抗帕金森:在疾病阴影下,如何重掌生活主动权?

帕金森病&#xff0c;一种影响全球超 1000 万人的神经退行性疾病&#xff0c;正无声地改变着患者的生活轨迹。随着大脑中多巴胺分泌减少&#xff0c;患者逐渐出现肢体震颤、肌肉僵硬、步态迟缓等症状&#xff0c;甚至连扣纽扣、端水杯这类日常动作都变得艰难。更棘手的是&#…