MySQL学习 [第一天] ——数据库的基本操作 Ⅰ

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 从零开始学习MySQL,学习使用这个“无敌好用”的数据库管理系统

一、前言

大数据的学习道路上离不开数据库的学习,我们学校在上学期开设了有关数据库的课程,但学习的是SQL Server,虽然不管使用什么数据库SQL语法都差不多,但是SQL Server在平时确实用的很少,所以本学期我准备重新开始学习数据库,并且以MySQL 8为学习目标,进一步学习有关数据库的知识。

MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之一。

MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

我学习参考的书籍是《MySQL 8从入门到精通》,我正在看,大家如果想去阅读,可以去微信阅读上看或者上网找免费的电子版学习,后续学习总结的内容都会依据这本书来为大家总结。

好啦,废话不多说,我们开始数据库的学习之旅!

二、我的环境

  • 电脑系统:Windows 11
  • 数据库管理系统版本:MySQL 8
  • 数据库管理工具:Nacicat Premium 16

三、数据库的创建与删除

1、数据库的创建

MySQL安装完成之后,它自动的生成几个系统的数据库,我们可以使用如下SQL语句来查询看看:

SHOW DATABASES;

image-20220919230750340.png

这些数据库都不能轻易删除,它们是MySQL所必需的,它们的作用在后面的学习中会讲到。

创建数据库是在系统磁盘上划分一块区域用于数据的存储和管理,在MySQL中创建数据库的基本SQL语法格式是:

CREATE DATABASE database_name;

database_name是要创建的数据库的名称,新建的数据库不能和已存在的数据库重名。

OK,现在我们来尝试创建我们的第一个数据库:

CREATE DATABASE test_db;

数据库创建好之后,我们再次使用上面的语句查看一下:

image-20220919232107684.png

OK,我们已经成功迈出了第一步了。

2、数据库的删除

删除数据库是将已经存在的数据库从磁盘空间上清除,清除之后,数据库中的所有数据也将一同被删除。MySQL中删除数据库的基本语法格式为:

DROP DATABASE database_name

用DROP DATABASE声明删除数据库后,数据库中存储的所有数据表和数据也将一同被删除,而且不能恢复,如果要删除的数据库不存在,就会报错。

我们试着将刚才创建的数据库删除:

image-20220919233156310.png

DROP DATABASE test_db;

我们刷新一下,就会发现数据库已经被成功删除了。

四、数据表的基本操作

在数据库中,数据表是数据库中最重要、最基本的操作对象,是数据存储的基本单位。数据表被定义为列的集合,数据在表中是按照行和列的格式来存储的。每一行代表一条唯一的记录,每一列代表记录中的一个域。

接下来我们将学习有关数据表的基本操作。

1、创建数据表

创建数据表的过程是规定数据列的属性的过程,同时也是实施数据完整性(包括实体完整性、引用完整性和域完整性等)约束的过程。

创建数据表的语句如下:

CREATETABLE<表名>(    字符串1, 数据类型 [列级别约束条件][默认值],    字符串2, 数据类型 [列级别约束条件][默认值],    ......
[表级别约束条件]);

创建数据表的前提是有一个数据库,我们在创建表时需要指定是在哪个数据库里创建表,例如我们先创建一个数据库,然后再创建一个表:

USE test_db;CREATETABLE tb_emp1 
( id INT(11),NAME VARCHAR(25),deptId INT(11),salary FLOAT);

image-20220920224450840.png

2、使用主键约束

主键,又称主码,是表中一列或多列的组合。主键约束要求主键列的数据唯一,并且不允许为空。主键能够唯一地标识表中的一条记录,可以结合外键来定义不同数据表之间的关系,并且可以加快数据库查询的速度。

主键分为两种类型:单字段主键和多字段联合主键。

  • 单字段主键
    语法格式如下:
字段名 数据类型 PRIMARY KEY [默认值]
  • 例如我们将刚才的表的id设置为主键,并命名为新的数据表tb_emp2:
USE test_db;CREATETABLE tb_emp2 
(id INT(11) PRIMARY KEY,name VARCHAR(25),deptId INT(11),salary FLOAT);
  • 我们还可以再所以列定义完之后再指定主键:
USE test_db;CREATETABLE tb_emp3
(id INT(11),name VARCHAR(25),deptId INT(11),salary FLOAT,PRIMARY KEY(id));
  • 多字段联合主键
    语法格式如下:
PRIMARY KEY [字段1, 字段2, ... ..., 字段n]
  • 例如,我们可以将name和deptId联合起来作为主键:
USE test_db;CREATETABLE tb_emp4
(name VARCHAR(25),deptId INT(11),salary FLOAT,PRIMARY KEY(name, deptId));
  • 这样name和deptId字段组合起来成为表tb_emp4的多字段联合主键。

3、使用外键约束

外键用来在两个表的数据之间建立连接,可以是一列或者多列。一个表可以有一个或多个外键。外键对应的是参照完整性,一个表的外键可以为空值,若不为空值,则每一个外键值必须等于另一个表中主键的某个值。

外键是表中的一个字段,需要对应另一个关联表的主键,设置外键的原因在于保证数据引用的完整性,在定义外键之后,就不允许删除在另一个表中具有关联关系的行了。

创建外键的语法格式是:

[CONSTRAINT <外键名>] FOREIGN KEY 字段1 [, 字段名2, ...]REFERENCES <主表名> 主键列1 [,  主键列2,...]

例如我们创建一个部门表tb_dept1:

USE test_db;CREATETABLE tb_dept1
(id INT(11) PRIMARY KEY,name VARCHAR(22)NOTNULL,location VARCHAR(50));

然后我们再创建一个数据表tb_emp5,让它的键deptId作为外键关联到tb_dept1的主键id:

USE test_db;CREATETABLE tb_emp5
(id INT(11) PRIMARY KEY,name VARCHAR(25),deptId INT(11),salary FLOAT,CONSTRAINT fk_emp_dept1 FOREIGN KEY(deptId) REFERENCES tb_dept1(id));

我们再表tb_emp5上添加了一个名为fk_emp_dept1的外键约束,外键为deptId,它依赖于表tb_dept1的主键id。

4、使用非空约束

非空约束意思为字段的值不能为空,字段再设置非空约束之后,如果不指定值,就会报错。

非空约束的语法格式为:

字段名 数据类型 NOTNULL

5、使用唯一约束

设置唯一约束要求该列唯一,可以为空,但只能出现一个空值,其作用是可以确保一列或者多列不出现重复着。

设置唯一约束可以再定义列之后直接指定唯一约束:

字段名 数据类型 UNIQUE

例如:

USE test_db;CREATETABLE tb_dept2
(id INT(11) PRIMARY KEY,name VARCHAR(25) UNIQUE,location VARCHAR(50));

设置唯一约束还可以再定义所以列之后指定唯一约束:

[CONSTRAINT <约束名>] UNIQUE(<字段名>)

例如:

USE test_db;CREATETABLE tb_dept3
(id INT(11) PRIMARY KEY,name VARCHAR(22),location VARCHAR(50),CONSTRAINT STH UNIQUE(name));

学到这里,有人可能会问,主键跟唯一约束不都是确定唯一值吗,它们有什么区别,我想说的是唯一约束在一个表中可以有多个字段声明,而且字段可为空值,但是主键只能声明一个,且不能为空。

6、使用默认约束

默认约束意思是指定某列的默认值,它的语法格式如下:

字段名 数据类型 DEFAULT 默认值

例如:

USE test_db;CREATETABLE tb_emp7
(id INT(11) PRIMARY KEY,name VARCHAR(25)NOTNULL,deptId INT(11) DEFAULT 0000,salary FLOAT);

我们将部门编号默认为0000,如果插入数据时不指定编号那么就是默认的编号。

五、最后我想说

开始部分内容比较多,我准备分成几个博客进行总结更新,接下来的博客依旧会继续更新有关数据库的基本操作内容,大家耐心等待,谢谢啦!

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
14天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
29 1
|
17天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
30 4
|
23天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
120 1
|
11天前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
109 0
|
1月前
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
132 6
|
1月前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
64 3
Mysql(4)—数据库索引
|
1月前
|
SQL Ubuntu 关系型数据库
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
本文为MySQL学习笔记,介绍了数据库的基本概念,包括行、列、主键等,并解释了C/S和B/S架构以及SQL语言的分类。接着,指导如何在Windows和Ubuntu系统上安装MySQL,并提供了启动、停止和重启服务的命令。文章还涵盖了Navicat的使用,包括安装、登录和新建表格等步骤。最后,介绍了MySQL中的数据类型和字段约束,如主键、外键、非空和唯一等。
71 3
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
|
26天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
77 2
|
29天前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
104 4
|
1月前
|
存储 关系型数据库 MySQL
如何在MySQL中创建数据库?
【10月更文挑战第16天】如何在MySQL中创建数据库?
下一篇
无影云桌面