对于数据库MySQL的基础学习与Datagrip的使用
1.MySQL概述
(1)相关概念
数据库 :存储数据的仓库 (DB)
数据库管理系统:操控和管理数据库的大型软件(DBMS)
SQL:操作关系型数据库的编程语言 定义的统一标准(SQL)
关系型数据库(RDBMS)
概念:建立在关系模型基础上,由多张互相连接的二位表组成的数据库
特点:1.使用表存储数据,格式统一,便于维护
2.使用SQL语句,标准统一,使用方便
(2)下载与启动
下载:教程省略(官网下载)
启动:可以使用客户端启动或者cmd命令窗口输入 mysql -u root -p 来使用(需要配置PATH环境变量)
2.SQL
(1)SQL通用语法
- SQL语句可以单行或者多行书写,以分号结尾
- SQL语句可以使用空格/缩进来增强语句的可读性
- MySQL数据库的SQL语句不区分大小写,关键字使用建议大写
- 注释:单行注释 -- 注释内容 或 #注释内容(MySQL特有)多行注释 /*注释内容*/
(2)SQL分类
(3)DDL
数据库操作
1.查询所有数据库
SHOW DATABASES;
2.查询当前数据库
SELECT DATABASE();
3.创建
CREALT DATABASE[IF NOT EXISTS] 数据库名 [DEFAULT CHARSET 字符集][COLLATE 规则];
4.删除
DROP DATABASE [IF EXISTS] 数据库名;
5.使用
USE 数据库名;
表操作 - 查询
1.查询当前数据库的所有表(先使用use进入数据库)
SHOW TABLES;
2.查询表结构
DESC 表名;
3.查询指定表的建表语句
SHOW CREATE TABLE 表名;
表操作 - 创建
CREATE TABLE 表名(
字段1 字段1类型[COMMENT 字段1注释],
字段2 字段2类型[COMMENT 字段2注释],
字段3 字段3类型[COMMENT 字段3注释],
.....
字段n 字段n类型[COMMENT 字段n注释]
)[COMMENIT 表注释];
表操作 - 数据类型
数值类型
字符串类型
日期时间类型
表操作 - 修改
1.添加字段
ALTER TABLE 表名 ADD 字符名 类型(长度)[COMMENT 注释 ][约束]
2.修改字段
ALTER TABLE 表名 ADD MODIFY 字段名 新数据类型(长度)
ALTER TABLE 表名 CHANGH 旧字段名 新字段名 类型(长度)[COMMENT 注释][约束]
3.删除字段
ALTER TABLE 表名 DROP 字段名;
4.修改表名
ALTER TABLE 表名 RENAME TO 新表名;
表操作 - 删除
1.删除表
DROP TABLE[IF EXISTS] 表名;
2.删除表 并重新创建该表
TRUNCATE TABLE 表名;
(后续开始使用图形界面)
(4)DML
对数据库中的表的数据记录进行增删改操作
添加数据 INSERT
给指定字段添加数据
INSERT INTO 表名(字段名1,字段名2,...)VALUES(值1,值2,...);
给全部字段添加数据
INSERT INTO 表名 VALUES(值1,值2,...);
批量添加数据
INSERT INTO 表名(字段名1,字段名2,...)VALUES(值1,值2,...),(值1,值2,...),(值1,值2,...);
INSERT INTO 表名 VALUES(值1,值2,...),(值1,值2,...),(值1,值2,...);
insert into user(id, name, age) VALUES (1,'H',20);
insert into user(id, name, age) VALUES (2,'W',19);
insert into user VALUES (3,'Y',18);insert into user VALUES (4,'D',18),(5,'F',23),(6,'E',21);
修改数据 UPDATE
UODATE 表名 SET 字段名1 = 值1,字段名2 = 值2[where 条件];
删除数据 DELETE
DELETE FROM 表名[WHERE 条件]
(5)DQL
数据查询语言 用来查询数据库中的表的记录
SELECT 字段列表 FROM 表名列表
WHRER 条件列表
GROUP BY 分组字段列表
HAVING 分组后条件列表
LIMIT 分页参数
基本查询
查询多个字段
SELECT 字段1,字段2,字段3.... FROM 表名;
SELECT * FROM 表名;(查询全部)
设置别名
SELECT 字段1 [AS 别名1],[AS 别名2]...FROM 表名;
去除重复记录
SELECT DISINCT 字段列表 FEOM 表名;
create table Student (ID int comment "学号",NAME varchar(3) comment "姓名",SEX char(1) comment "性别",BAR DATE comment "出生年月",SCORE double comment "绩点"
)comment "学生表";insert into Student VALUES (1001,'陈平安','男','2018-05-05',4.1),(1002,'宁姚','女','2018-01-04',5.0),(1003,'陈清流','男','2018-05-02',3.2),(1004,'陈暖树','女','2020-06-12',3.6),(1005,'裴钱','女','2020-11-25',3.4);select ID,NAME from Student;
条件查询
SELECT 字段列表 FROM 表名 WHERE 条件列表
聚合函数
将一列数据作为一个整体 进行纵向计算
常见聚合函数
-- 聚合函数 --
select count(SEX) from Student;select max(SCORE) from Student;select avg(SCORE) from Student;select sum(SCORE) from Student;
分组查询
SELECT 字段列表 FROM 表名 [WHERE 条件] GROUP BY 分组字段名 [HAVING 分组后过滤条件]
- where和having的区别
执行时机不同: where在分组前执行 having在分组后对结果进行过滤
判断条件不同:where不能对聚合函数进行判断 having可以
-- 分组查询 --
select SEX,count(SEX) from Student group by SEX;select sex,avg(SCORE) from Student group by sex;
排序查询
SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1,字段2 排序方式2;
-- 排序查询 --
select * from Student order by SCORE;select *from Student order by SCORE desc ;
分页查询
SELECT 字段列表 FROM 表名 LIMIT 起始索引,显示记录数;
执行顺序
(6)DCL
用来管理数据库 用户,控制数据库的访问和权限
用户管理
查询用户
USE mysql
SELECT * FROM user;
创建用户
CREATE USER ‘用户名’@‘主机名’ IDENTIFIED BY ‘新密码'
修改用户密码
CREATE USER ‘用户名’@‘主机名’ IDENTIFIED WITH mysql_native_password BY '新密码'
删除用户
DROP USER ‘用户名’@‘主机名’;
权限控制
MySQL的常用权限
查询权限
SHOW GRANTS FOR '用户名'@'主机名';
授予权限
GRANT 权限列表 ON 数据库名.表名 TO ‘用户名’ @ ‘主机名’;
授权时可以使用 * 进行通配数据库名和表名使用
撤销权限
REMOVE 权限列表 ON 数据库名.表名 FROM ‘用户名’ @ ‘主机名’;
3.函数
(1)字符串函数
(2)数值函数
(3)日期函数
(4)流程函数
实现条件筛查
4.约束
概念:约束是作用于表中字段上的规则 用于限制存储在表中的数据
目的:保证数据库中的数据的正确 有效和完整性
*在创建或者修改表的时候添加 了解主键(一个表只有一个)和外键
5.多表查询
(1)概述
就是在多张表中查询数据
多表关系
一对多 | 在多的一方设置外键 关联少一方的主键 |
多对多 | 建立中间表 包含两个外键 关联两张表的主键 |
一对一 | 用于表结构的拆分 在其中任何一方设置外键(UNQUE) 关联令一方的主键 |
(2)内连接
隐式内连接
SELECT 字段列表 FROM 表1,表2 WHERE 条件...;
显示内连接
SELECT 字段列表 FROM 表1[ INNER ] JOIN 表2 ON 连接条件...;
* 在起别名后 后续只能使用别名
(3)外连接
左外连接
SELECT 字段列表 FROM 表1 LEFT [ OUTER ] JOIN 表2 ON 条件...;
* 查询表1的所有数据 包含表1和 表2 的交集部分的数据
右外连接
SELECT 字段列表 FROM 表1 RIGHT [ OUTER ] JOIN 表2 ON 条件...;
* 查询表2的所有数据 包含表1和 表2 的交集部分的数据
(4)自连接
SELECT 字段列表 FROM 表A 别名A JOIN 表A 别名B ON 条件...;
union all union
SELECT 字段列表 FROM 表A ...
UNION [ ALL ]
SELECT 字段列表 FROM 表B...
* UNION ALL直接将查询结果合并 UNION 还会去重
*对于联合查询的多张表的列数和字段类型需要保持一致
(5)子查询
SQL 语句中嵌套SELECT语句 称为嵌套查询 又称子查询
SELECT 字段列表 FROM 表名 WHERE columnl = (SELECT columnl FROM t2);
[1] 标量子查询 (单个值)
常用操作符号 = > < > = <=
[2] 列子查询(一列)
常用操作符号 IN,NOT IN,ANY,SOME,ALL
[3] 行子查询(一行)
常用操作符号 =, <>,IN,NOT,IN
查询结果是一行多列的
eg. SELECT * FROM T1 WHERE (SNO,SNAME) = (SELECET SNO,SNAME FROM T2);
[4] 表子查询(一表)
常用操作符号 IN
eg. SELECT * FROM T1 WHERE (SNO,SNAME) IN (SELECET SNO,SNAME FROM T2);
6.事务
事务简介
事务 是一组操作的集合 是一个不可分割的工作单位 事务会把所有操作作为一个整体一起向系统提交或撤销操作请求 要么同时成功 要么同时失败
事务操作
*查看/设置事务提交方式
SELECT @@ autocommit;
SET @@autocommit = 0;
*提交事务
COMMT;
*回滚事务
ROLLBACK;
事务四大特性
- 原子性(A):事务是不可分割的最小操作单元 要么全部成功 要么全部失败
- 一致性(C):事务完成时 必须使所有的数据都保持一致状态
- 隔离性(I):数据库系统提供的隔离机制 保证事务在不受外部操作影响的独立环境下运行
- 持久性(D):事务一旦提交或回滚 它对数据中的数据的改变就是永久的
并发事务问题
事务隔离级别
学习时间 2024-10-30