目录
📖前言:
SQL语言有40多年的历史,从它被应用至今几乎无处不在。我们消费的每一笔支付记录,收集的每一条用户信息,发出去的每一条消息,都会使用数库或与其相关的产品来据存储,而操纵数据库的语言正是 SQL !!!
SQL相当于一种工具,它可以帮助我们完成工作,创造价值。 本文就来详细讲解SQL的相关概念与操作,为后面的数据库深入学习打下基础。
😺😺😺数据库与SQL相关说明:
名称 | 全称 | 简称 |
数据库 |
存储数据的仓库,数据是有组织的进行存储 |
DataBase ( DB ) |
数据库管 理系统 |
操纵和管理数据库的大型软件 |
DataBase Management
System (DBMS) |
SQL |
操作关系型数据库的编程语言,定义了一套操作关系型数据库统一标准 |
Structured Query
Language (SQL) |
📑SQL概述&&通用语法:
SQL,全称 Structured Query Language,结构化查询语言。操作关系型数据库的编程语言,定义了一套操作关系型数据库统一标准 。
😀学习SQL的作用:
SQL 是一门 ANSI 的标准计算机语言,用来访问和操作数据库系统。SQL 语句用于取回和更新数据库中的数据。
- SQL 可创建新数据库
- SQL 面向数据库执行查询
- SQL 可从数据库取回数据
- SQL 可在数据库中插入新的记录
- SQL 可从数据库删除记录
- SQL 可更新数据库中的数据
👌SQL分类:
🧐SQL通用语法:
- SQL语句可以单行或多行书写,以分号结尾。
-
SQL 语句可以使用空格 / 缩进来增强语句的可读性
-
MySQL 数据库的 SQL 语句不区分大小写,关键字建议使用大写。* 注释:1)单行注释: -- 注释内容 或 # 注释内容2)多行注释: /* 注释内容 */
好了,通过上面的一些说明,想必你对SQL有了一定了解了,那我们直接开始SQL的学习吧~~~
🐳DDL:
Data Definition Language,数据定义语言,用来定义数据库对象(数据库,表,字段)
🐻操作数据库:
这里先列出总的语法,后面依次解释说明:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | # 库操作 -- 1.1 查询所有数据库 show databases ; -- 1.2 查询当前数据库 select database () ; -- 1.3 创建数据库 create database [ if not exists ] 数据库名 [ default charset 字符集 ] [ collate 排序 规则 ] ; -- 1.4 删除数据库 drop database [ if exists ] 数据库名 ; -- 1.5 切换数据库 use 数据库名 ; # 表操作: -- 2.1 查询当前数据库所有表 show tables; -- 2.2 查看指定表结构 desc 表名 ; -- 2.3 查询指定表的建表语句 show create table 表名 ; -- 2.4 创建表结构 create table 表名( 字段1 字段1类型 [comment 字段1注释 ], 字段2 字段2类型 [comment 字段2注释 ], 字段3 字段3类型 [comment 字段3注释 ], ...... 字段n 字段n类型 [comment 字段n注释 ] ) [ comment 表注释 ] ; |
- 查询所有数据库:
1 | show databases ; |
------->可以看到这里有四个系统自带的数据库
- 创建数据库:
1 2 3 4 | create database [ if not exists ] 数据库名 [ default charset 字符集 ] [ collate 排序 规则 ] ; /* create database if not exists 数据库名 --->如果数据库已经存在(同名)则不创建,否则创建*/ /*中括号中的内容是可选的,可以写也可以不写*/ |
在mysql中输入下面指令,名为itcast的数据库创建成功
- 查询当前数据库:
1 | select database () ; |
- 切换数据库 :
1 | use itcast; |
-
删除数据库 :
1 2 3 4 | drop database [ if exists ] 数据库名 ; /*如果删除一个不存在的数据库,将会报错。 此时,可以加上参数 if exists ,如果数据库存在,再 执行删除,否则不执行删除。*/ |
🐞数据类型:
在建表语句中,我们指定字段的数据类型时,常常用到int ,varchar,那么在MySQL中除了 以上的数据类型,还有哪些常见的数据类型呢? 接下来,我们就来详细介绍一下MySQL的数据类型。
MySQL中的数据类型有很多,主要分为三类:数值类型、字符串类型、日期时间类型。
🦏🦏🦏常用类型:
- int:整型
- double:浮点型,例如 double(5,2)表示最多 5 位,其中必须有 2 位小数,即最大值为 999.99;
- decimal:泛型型,在表单线方面使用该类型,因为不会出现精度缺失问题;
- char:固定长度字符串类型;(当输入的字符不够长度时会补空格)
- varchar:固定长度字符串类型;
- text:字符串类型;
- blob:字节类型;
- date:日期类型,格式为:yyyy-MM-dd;
- time:时间类型,格式为:hh:mm:ss
- timestamp:时间戳类型;
更多数据类型可以查看这篇文章:最全 SQL 字段类型(4种)、属性(6种)总结_sql字段类型-CSDN博客
🦉操作表:
- 创建表:
🐞🐞🐞注意:[ ] 中的内容是可选的,最后一个字段没有逗号.
那么建表语句为:
1 2 3 4 5 6 | create table tb_user( id int comment '编号' , name varchar (50) comment '姓名' , age int comment '年龄' , gender varchar (1) comment '性别' ) comment '用户表' ; |
- 查询当前数据库所有表:
1 | show tables; |
-
. 查看指定表结构:
- 查询指定表的建表语句:
1 | show create table 表名 ; |
上述,我们已经讲解了通过DDL语句,如何操作数据库、操作表、操作表中的字段,而通过DDL语句执 行在命令进行操作,主要存在以下两点问题:
1).会影响开发效率 ;
2). 使用起来,并不直观,并不方便 ;
所以,后续语法与操作展示我将在SQL图示化工具------Vavicat中展示,感兴趣的小伙伴可已自行下载:Navicat 中国 | 支持 MySQL、Redis、MariaDB、MongoDB、SQL Server、SQLite、Oracle 和 PostgreSQL 的数据库管理
🦦DML:
DML英文全称是Data Manipulation Language(数据操作语言),用来对数据库中表的数据记录进 行增、删、改操作。
语法规则:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | -- 1. 添加数据 # 1.1 给指定字段添加数据 INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...); # 1.2 给全部字段添加数据 INSERT INTO 表名 VALUES (值1, 值2, ...); # 1.3 批量添加数据 INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...), (值1, 值2, ...), (值 1, 值2, ...) ; -- 2. 修改数据 UPDATE 表名 SET 字段名1 = 值1 , 字段名2 = 值2 , .... [ WHERE 条件 ] ; /* 没有条件 where 表示将表中的所有数据都进行修改*/ -- 3. 删除数据 DELETE FROM 表名 [ WHERE 条件 ] ; /* 没有条件 where 相当于删除所有数据 */ |
按照上述操作,我们创建表并给表插入信息:
案例演示:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | -- 查看所有数据库 show databases; -- 创建itcast数据库 create database if not exists itcast; -- 使用当前数据库 use itcast; -- 创建员工表 create table emp( id int comment '编号' , workno varchar (10) comment '工号' , name varchar (10) comment '姓名' , gender char (1) comment '性别' , age tinyint unsigned comment '年龄' , idcard char (18) comment '身份证号' , workaddress varchar (50) comment '工作地址' , entrydate date comment '入职时间' )comment '员工表' ; -- 展示所创建的表信息 desc emp; -- 加入表中成员 INSERT INTO `emp` (`id`, `workno`, ` name `, `gender`, `age`, `idcard`, `workaddress`, `entrydate`) VALUES (1, '0001' , ' 柳岩' , '女' , 19, ' 123445' , '北京' , '2024-04-01' ); INSERT INTO `emp` (`id`, `workno`, ` name `, `gender`, `age`, `idcard`, `workaddress`, `entrydate`) VALUES (2, '0002' , '坤坤' , '男' , 20, '34568' , '北京' , '2024-04-02' ); INSERT INTO `emp` (`id`, `workno`, ` name `, `gender`, `age`, `idcard`, `workaddress`, `entrydate`) VALUES (3, '0004' , '张三' , '男' , 22, '45678' , '上海' , '2024-04-03' ); INSERT INTO `emp` (`id`, `workno`, ` name `, `gender`, `age`, `idcard`, `workaddress`, `entrydate`) VALUES (4, '0005' , '李四' , '男' , 18, '23535' , '深圳' , '2024-04-05' ); INSERT INTO `emp` (`id`, `workno`, ` name `, `gender`, `age`, `idcard`, `workaddress`, `entrydate`) VALUES (5, '0006' , '小明' , '男' , 35, '23535' , '福建' , '2024-04-06' ); INSERT INTO `emp` (`id`, `workno`, ` name `, `gender`, `age`, `idcard`, `workaddress`, `entrydate`) VALUES (6, '0007' , '丽华' , '女' , 34, '135252' , '天津' , '2024-04-07' ); INSERT INTO `emp` (`id`, `workno`, ` name `, `gender`, `age`, `idcard`, `workaddress`, `entrydate`) VALUES (8, '0008' , '小猫' , '女' , 18, '1235215' , '福建' , '2024-04-05' ); INSERT INTO `emp` (`id`, `workno`, ` name `, `gender`, `age`, `idcard`, `workaddress`, `entrydate`) VALUES (9, '0009' , '凉凉' , '男' , 20, '12345135' , '西安' , '2024-04-04' ); INSERT INTO `emp` (`id`, `workno`, ` name `, `gender`, `age`, `idcard`, `workaddress`, `entrydate`) VALUES (10, '0010' , '菜菜' , '女' , 19, '135235' , '安徽' , '2024-04-02' ); -- 这里先用来查看所有表中信息,后续会讲到 select * from emp; /* 这里是不运行的部分,仅作展示 -- 修改表中信息: update emp set name = '小王' where id = 1; update emp set entrydate = '2008-01-01' ; -- 没有条件where就是全部修改 -- 删除表中数据 delete from emp where gender = '女' ; */ |
运行结果:
注意:
- DELETE 语句的条件可以有,也可以没有,如果没有条件,则会删除整张表的所有数据。
- DELETE 语句不能删除某一个字段的值(可以使用UPDATE,将该字段值置为NULL即可)。
- 所有字符串数据必须使用单引用!
🦏DQL:
DQL英文全称是Data Query Language(数据查询语言),数据查询语言,用来查询数据库中表的记 录。查询关键字: SELECT
在一个正常的业务系统中,查询操作的频次是要远高于增删改的,当我们去访问企业官网、电商网站, 在这些网站中我们所看到的数据,实际都是需要从数据库中查询并展示的。而且在查询的过程中,可能 还会涉及到条件、排序、分页等操作。比如京东购物网站:
语法规则:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | # 基础查询 -- 1.1 查询多个字段 SELECT 字段1, 字段2, 字段3 ... FROM 表名 ; SELECT * FROM 表名 ; -- 带*号是查询所有字段 -- 1.2 字段设置别名: SELECT 字段1 [ AS 别名1 ] , 字段2 [ AS 别名2 ] ... FROM 表名; SELECT 字段1 [ 别名1 ] , 字段2 [ 别名2 ] ... FROM 表名; -- as可以省略 -- 1.3 去除重复记录 SELECT DISTINCT 字段列表 FROM 表名; -- 保留不同的字段 # 条件查询 SELECT 字段列表 FROM 表名 WHERE 条件列表 ; #聚合函数 SELECT 聚合函数(字段列表) FROM 表名 ; #分组查询 SELECT 字段列表 FROM 表名 [ WHERE 条件 ] GROUP BY 分组字段名 [ HAVING 分组 后过滤条件 ]; # 排序查询 SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1 , 字段2 排序方式2 ; ASC : 升序(默认值) -- 排序方式 DESC : 降序 -- 排序方式 # 分页查询 SELECT 字段列表 FROM 表名 LIMIT 起始索引, 查询记录数 ; |
案例演示:
# 基础查询:
A.查询指定字段 name, workno, age并返回:
1 | select name ,workno,age from emp; |
B:查询返回所有字段:
1 2 | select id ,workno, name ,gender,age,idcard,workaddress,entrydate from emp; -- 1 select * from emp; -- 2 |
C:查询所有员工的工作地址,起别名:
1 | select workaddress ( as ) '工作地址' from emp; -- as 可以省略 |
D:查询公司员工的上班地址有哪些(不要重复):
1 | select distinct workaddress '工作地址' from emp; |
D:这里演示最后一个查询结果,其他类似(以DML中创建的员工表为例):
# 条件查询:
常用的比较运算符如下:
常用的逻辑运算符如下:
案例:
A. 查询年龄等于 88 的员工:
1 | select * from emp where age = 88; |
B.查询年龄小于等于 20 的员工信息:
1 | select * from emp where age <= 20; |
C.查询年龄在15岁(包含) 到 20岁(包含)之间的员工信息:
1 2 3 | select * from emp where age >= 15 && age <= 20; -- 1 select * from emp where age >= 15 and age <= 20; -- 2 select * from emp where age between 15 and 20; -- 3 |
D.查询身份证号最后一位是X的员工信息:
1 2 3 4 | -- % 匹配任意个字符 select * from emp where idcard like '%X' ; -- _ 匹配一个字符,若身份证号18位,则X前有17个空格 select * from emp where idcard like '_________________X' ; |
D:这里演示最后一个查询结果,其他类似(以DML中创建的员工表为例):
#聚合函数:
将一列数据作为一个整体,进行纵向计算 ,下面展示常见聚合函数:
注意 : NULL值是不参与所有聚合函数运算的!!!
案例:
A. 统计该企业员工数量:
1 2 | select count (*) from emp; -- 统计的是总记录数,含创建的null字段 select count (idcard) from emp; -- 统计的是idcard字段不为null的记录数 |
B.统计该企业员工的平均年龄:
1 | select avg (age) from emp; |
C. 统计该企业员工的最大年龄:
1 | select max (age) from emp; |
D.统计福建地区员工的年龄之和:
1 | select sum (age) from emp where workaddress = '福建' ; |
D:这里演示最后一个查询结果,其他类似(以DML中创建的员工表为例):
# 分组查询:
1 2 | SELECT 字段列表 FROM 表名 [ WHERE 条件 ] GROUP BY 分组字段名 [ HAVING 分组 后过滤条件 ]; |
🐻🐻🐻 where 和 having的区别:
- 执行时机不同:where是分组之前进行过滤,不满足where条件,不参与分组;而having是分组 之后对结果进行过滤。
- 判断条件不同:where不能对聚合函数进行判断,而having可以。
案例:
A. 根据性别分组 , 统计男性员工 和 女性员工的数量:
1 | select gender, count (*) from emp group by gender ; |
B. 根据性别分组 , 统计男性员工 和 女性员工的平均年龄:
1 | select gender, avg (age) from emp group by gender |
C. 查询年龄小于45的员工 , 并根据工作地址分组 , 获取员工数量大于等于2的工作地址:
1 2 | select workaddress, count (*) address_count from emp where age < 45 group by workaddress having address_count >= 2; |
C:这里演示最后一个查询结果,其他类似(以DML中创建的员工表为例):
#排序查询:
1 | SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1 , 字段2 排序方式2 ; |
注意:
- 如果是升序, 可以不指定排序方式ASC ;
- 如果是多字段排序,当第一个字段值相同时,才会根据第二个字段进行排序 ;
案例:
A. 根据年龄对公司的员工进行升序排序:
1 2 | select * from emp order by age asc ; select * from emp order by age; -- 默认升序排序 |
B.根据年龄对公司的员工进行升序排序 , 年龄相同 , 再按照入职时间进行降序排序:
1 | select * from emp order by age asc , entrydate desc ; |
B:这里演示最后一个查询结果,其他类似(以DML中创建的员工表为例):
#分页查询:
分页操作在业务系统开发时,也是非常常见的一个功能,我们在网站中看到的各种各样的分页条,后台 都需要借助于数据库的分页操作。
1).语法:
1 | SELECT 字段列表 FROM 表名 LIMIT 起始索引, 查询记录数 ; |
注意事项:
- 起始索引从0开始,起始索引 = (查询页码 - 1)* 每页显示记录数。
- 分页查询是数据库的方言,不同的数据库有不同的实现,MySQL中是LIMIT。
- 如果查询的是第一页数据,起始索引可以省略,直接简写为 limit 10(一页10条信息)。
案例:
A.查询第1页员工数据, 每页展示10条记录:
1 2 | select * from emp limit 0,10; select * from emp limit 10; -- 第一页,0可以省略 |
B.查询第2页员工数据, 每页展示10条记录 --------> (页码-1)*页展示记录数:
1 | select * from emp limit 10,10; |
A:这里演示第一个查询结果,其他类似(以DML中创建的员工表为例):
执行顺序:
在讲解DQL语句的具体语法之前,我们已经讲解了DQL语句的完整语法,及编写顺序,接下来,我们要来说明的是DQL语句在执行时的执行顺序,也就是先执行那一部分,后执行那一部分,下面一张图说明执行顺序:
🫎DCL:
DCL英文全称是Data Control Language(数据控制语言),用来管理数据库用户、控制数据库的访 问权限。
语法规则:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | # 管理用户 -- 1.1 查询用户 select * from mysql. user ; -- 1.2 创建用户 -- 1.3 修改用户密码 -- 1.4 删除用户 DROP USER '用户名' @ '主机名' ; # 权限控制 -- 2.1 查询权限 SHOW GRANTS FOR '用户名' @ '主机名' ; -- 2.2 授予权限 GRANT 权限列表 ON 数据库名.表名 TO '用户名' @ '主机名' ; -- 2.3 撤销权限 REVOKE 权限列表 ON 数据库名.表名 FROM '用户名' @ '主机名' ; |
注意:
- 在MySQL中需要通过用户名@主机名的方式,来唯一标识一个用户。
- 主机名可以使用 % 通配。
- 这类SQL开发人员操作的比较少,主要是DBA( Database Administrator 数据库 管理员)使用。
对于权限控制,官方提供了许多方法 ,可以参考:MySQL :: MySQL 8.0 Reference Manual :: 8.2.2 Privileges Provided by MySQL
这里不做过多展示了,有兴趣的小伙伴可以自行想学习相应规则
结语: 写博文不仅仅是为了分享学习经历,同时这也有利于我巩固知识点,总结该知识点,由于作者水平有限,对文章有任何问题的还请指出,接受大家的批评,让我改进。同时也希望读者们不吝啬你们的点赞+收藏+关注,你们的鼓励是我创作的最大动力!