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

数据库入门:从零开始构建你的第一个数据库

欢迎来到数据库的世界!今天,我们将一起探索如何创建、管理和查询数据库。无论你是初学者还是希望加深理解的开发者,这篇博客都将帮助你更好地掌握数据库的基础知识。

一、数据库的基本操作

创建数据库

首先,让我们从创建一个新数据库开始。想象一下数据库就像是一个巨大的文件柜,每个文件柜都有自己的名字和用途。使用以下SQL语句可以创建一个新的文件柜(数据库):

CREATE DATABASE IF NOT EXISTS mydb;

这行代码的意思是:如果不存在名为mydb的数据库,则创建它。你可以用SHOW DATABASES;查看所有已有的文件柜。

使用和修改数据库

选择了要工作的文件柜后,可以通过USE mydb;进入它。如果你想改变这个文件柜的语言设置(字符集),可以这样做:

ALTER DATABASE mydb CHARACTER SET utf8mb4;

最后,如果你不再需要某个文件柜了,可以用DROP DATABASE IF EXISTS mydb;将其删除。

二、数据表的操作

在数据库中,数据是以表格的形式存储的。这些表格就像Excel中的工作表一样,每列代表一种类型的数据。

创建和查看表格

创建表格的过程类似于设计一张信息收集表。为了查看表格的设计结构,可以使用:

DESC students;

这将显示表格的所有列及其属性。想要详细了解表格是如何被创建的?试试SHOW CREATE TABLE students;

修改表格结构

随着时间的发展,你可能需要对表格进行调整。比如,添加新的信息字段(列):

ALTER TABLE students ADD email VARCHAR(100);

或者修改已有字段的类型:

ALTER TABLE students MODIFY age TINYINT;

甚至重命名字段或删除不需要的字段也是常有的事:

ALTER TABLE students CHANGE email student_email VARCHAR(100);
ALTER TABLE students DROP student_email;

三、数据的插入、更新和删除

这部分涉及到如何向表格中添加数据、更新现有数据以及删除数据。

  • 插入数据:向表格中添加一行或多行数据。
    INSERT INTO students (name, age) VALUES ('张三', 20), ('李四', 21);
  • 更新数据:根据条件更新特定行的数据。
    UPDATE students SET age = 23 WHERE name = '张三';
  • 删除数据:删除符合条件的数据行。
    DELETE FROM students WHERE age > 22;

四、约束与索引

约束用于确保数据的准确性和一致性。例如,主键约束保证每一行都有唯一的标识符,非空约束确保某些列不能为空等。

  • 主键:每个表格只能有一个主键,它可以由一个或多个列组成。
    ALTER TABLE table_name ADD PRIMARY KEY (column_name);
  • 自增:通常与主键一起使用,自动为每条记录生成唯一的ID。
    id INT AUTO_INCREMENT,
    PRIMARY KEY(id)

五、查询数据

查询是数据库中最常用的功能之一。通过不同的查询语句,我们可以轻松获取所需的信息。

  • 基本查询:选择表格中的所有列或指定列。
    SELECT * FROM students;
    SELECT name, age FROM students;
  • 排序查询:按照指定的顺序排列结果。
    SELECT * FROM students ORDER BY age ASC;
  • 聚合查询:用于统计分析,如计算总数、平均值等。
    SELECT COUNT(*) AS total_students FROM students;

总结来说,数据库管理不仅仅是关于数据的存储,它还涉及到如何高效地组织、访问和保护数据。希望通过这篇博客,你能对数据库有一个更加清晰的理解。

下一篇博客我们将开始走进数据库的基础的一些语法

http://www.dtcms.com/a/319225.html

相关文章:

  • idea工具maven下载报错:PKIX path building failed,配置忽略SSL检查
  • [Oracle] CEIL()函数
  • 无人机航拍数据集|第7期 无人机绵羊红外目标检测YOLO数据集1964张yolov11/yolov8/yolov5可训练
  • 计算虚拟化技术
  • vscode.window.activeTextEditor 获取不到 png 图片路径问题
  • 僵尸进程问题排查
  • Github创建仓库,克隆提交代码到远程
  • 内存泄漏系列专题分析之三十二:高通相机CamX ION/dmabuf内存管理机制CmdBuffer
  • 【3D图像技术分析与实现】谷歌的AlphaEarth是如何实现的?
  • 鸿蒙RichEditor
  • 使用萤石云播放视频及主题模版配置
  • python安装部署rknn-toolkit2(ModuleNotFoundError: No module named ‘rknn_toolkit2‘)
  • 技术速递|Copilot Coding Agent:自定义设置步骤更可靠、更易于调试
  • P8250 交友问题
  • 表单元素与美化技巧:打造用户友好的交互体验
  • zookeeper因jute.maxbuffer启动异常问题排查处理
  • 如何开发一个运行在windows系统服务器上的服务
  • “物联网+职业本科”:VR虚拟仿真实训室的发展前景
  • 纳米陶瓷与光子集成:猎板PCB定义下一代VR硬件的技术蓝图
  • 【unity实战】使用Unity程序化生成3D随机地牢(附项目源码)
  • 飞机起落架轮轴深孔中间段电解扩孔内轮廓测量 - 激光频率梳 3D 轮廓检测
  • 如何将Dubbo从Zookeeper平滑地迁移到Nacos?
  • 38.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--扩展功能--增加日志记录器
  • Android视图状态以及重绘
  • Java面试宝典:类加载
  • 利用vue.js2X写前端搜索页面,express写后端API接口展现搜索数据
  • SymPy 中 atan2(y, x)函数的深度解析
  • vue3对比vue2的性能优化和提升 :Vue 3 vs Vue 2
  • ArkTS: McPointChart
  • 【Redis面试精讲 Day 16】Redis性能监控与分析工具