MYSQL数据库学习
mysql的启动
net start mysql
net stop mysql
MYSQL客户端的连接
mysql -h 127.0.0.1 -p 3306 -u root -p
SQL
SQL通用语法
SQL分类
SQL语句,其功能主要分为四类:DDL,DML,DQL,DCL
DDL
数据库操作
查询所有数据库
show database;
查询当前数据库
select database() ;
创建数据库
create database 数据库名;
删除数据库
drop database [if exists] 数据库名;
切换数据库
use 数据库名 ;
表操作
表操作-查询创建
查询当前数据库所有表
show tables;
查看指定表结构
desc 表名;
查询指定表的建表语句
show create table 表名;
创建表结构
CREATE TABLE 表名(
字段1 字段1类型 [ COMMENT 字段1注释 ],
字段2 字段2类型 [COMMENT 字段2注释 ],
字段3 字段3类型 [COMMENT 字段3注释 ],
…
字段n 字段n类型 [COMMENT 字段n注释 ]
) [ COMMENT 表注释 ] ;
create table tb_user(
id int comment ‘编号’,
name varchar(50) comment ‘姓名’,
age int comment ‘年龄’,
gender varchar(1) comment ‘性别’
) comment ‘用户表’;
表操作-修改
添加字段
[ COMMENT 注释] [约束];ALTER TABLE 表名 ADD 字段名 类型(长度) [ COMMENT 注释] [约束];
修改数据类型
ALTER TABLE 表名 MODIFY 字段名 新数据类型;
修改字段名和字段类型
alter table 表名 change 旧字段名 新字段名 类型(长度) [comment 注释] [约束];
删除字段
alter table 表名 drop 字段名
修改表名
alter table 表名 rename to 新表名
表操作-删除
删除表
drop table [if exists ] 表名;
删除指定表,并重新创建表
truncate table 表名;
DML
● 添加数据
● 修改数据
● 删除数据
b. 给全部字段添加数据
insert into 表名 values(值1,值2,…);
c. 批量添加数据
insrt into 表名(字段名1,字段名2,…) values(值1,值2,…),(值1,值2,…),(值1,值2,…);
insert into 表名 values (值1,值2,…),(值1,值2,…),(值1,值2,…);
d. 修改数据·
update 表名 set 字段名1 = 值1,字段名2 = 值2 ,…[where 条件];
e. 删除数据
delete from 表名 [where 条件];
注意事项
■ delete 语句的条件可以没有,也可以有,如果没有条件,将删除整张表
■ delete语句不能删除某一个字段的值可以使用update ,将该字段值设置为NULL即可
■ 当进行删除全部数据操作时,datagrip会提示我们,询问是否确认删除
DQL
数据库查询语言
查询关键字 select
在一个正常的业务系统中,查询操作的频次是远高于增删改的,我们去访问企业官网,电商网站,在这些网站中我们所能看到的数据,实际都是需要从数据库中查询并展示的,而且在查询的过程中,可能还会涉及条件,排序,分页等操作
基本语法
select 字段列表
from 表名列表
where 条件列表
group by 分组字段列表
having 分组后条件列表
order by 排序字段列表
limit 分页参数
● 基本查询(不带条件)
● 条件查询(where)
● 聚合函数(count,max,min,avg,xum)
● 分组查询(group by)
● 排序查询(order by)
● 分页查询(limit)
基础查询
约束
约束是作用于表中字段上的规则,用于限制存储在表中的数据
保证数据库中数据的正确,有效性和完整性
分类
● 非空约束 限制该字段数据不能为null
● 唯一约束 保证该字段的所有数据都是唯一,不重复的
● 主键约束 主键是一行数据的唯一标识,要求非空且唯一
● 默认约束 保存数据时,如果未指定该字段的值,则采用默认值
● 检查约束 保证字段值满足某一个条件
● 外键约束 用来让两张表的数据之间建立连接,保证数据的一致性和完整性
约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束
约束演示
需求如下:
外键约束
用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性
我们来看一个例子:
左侧的emp表是员工表,里面存储员工的基本信息,包含员工的ID,姓名,年龄,职位,薪资,入职日期,上级主管ID,部门ID,在员工的信息存储的是部门ID dept_id,而这个部门的ID是关联的部门表dept的主键id,那emp表的dept_id就是外键,关联的是另一张表的主键
注意:目前上述两张表,只是在逻辑上存在这样一层关系。在数据库层面,并未建立外键关联,所以是无法保证数据的一致性和完整性的
语法:
多表查询概述
多表查询就是指从多张表中查询数据
分类
● 连接查询
○ 内连接,相当于查询A,B交集部分数据
○ 外连接
■ 左外连接:查询左表所有数据,以及两张表交集部分数据
■ 右外连接: 查询右表所有数据,以及两张表交集部分数据
■ 自动连接:当前表与自身的连接查询,自连接必须使用表别名
● 子查询
● 内连接
○ 内连接查询的是两张表交集部分的数据
○ 内连接的语法分为两种:隐式内连接,显式内连接
○ 隐式内连接:
select 字段列表 from 表1,表2 where 条件…;
显式内连接
select 字段列表 from 表1 [inner] join 表2 on 连接条件 …;
外连接
● 左外连接
select 字段列表 from 表1 left [outer] join 表2 on 条件…;
左外连接相当于查询表1(左表)的所有数据,当然也包含表1和表交集部分的数据。
● 右外连接
select 字段列表 from 表1 right [outer] join 表2 on 条件…;
右外连接相当于查询表2 (右表)的所有数据,当然也包含表1和表2交集部分的数据。
左外连接和右外连接是可以相互替换的,只需要调整在连接查询时SQL中,表结构的先后顺序就可以了,而我们在日常开发使用时,更偏向于左外连接
自连接
一张表连接查询多次
对于自连接可以是内连接也可以是外连接
select 字段列表 from 表A 别名A join 表A 别名B on 条件 …,
在自连接查询中,必须要为表起别名,要不然,我们不清楚所指的条件,返回的字段,到底是哪一张表的字段
联合查询
对于union查询,就是把多次查询的结果合并起来,形成一个新的查询结果集
select 字段列表 from 表A…
union all
select 字段列表 from 表B…
● 对于联合查询的多张表的列数必须保持一致,字段类型也需要保持一致
● union all 会将全部的数据直接合并在一起,union会对合并之后的数据去重
如果多条查询语句查询出来的结果,字段数量不一致,在进行union/union all 联合查询时,将会报错
子查询
sql语句中嵌套select语句,称为嵌套查询,又称子查询
select * from t1 where volum1 = (select column1 from t2);
子查询外部的语句可以是insert / update /delete /select中的任何一个
分类
根据子查询结果不同,分为:
A.标量子查询(子查询结果为单个值)
B.列子查询(子查询结果为一列)
C.行子查询(子查询结果为一行)
D.表子查询(子查询结结构为多行多列)
根据子查询位置,分为:
where之后
from之后
select之后
标量子查询‘
子查询返回的结果是单个值(数字,字符串,日期等),最简单的形式,这种子查询称为标量子查询
= <> > >= < <=
列查询:
子查询返回的结果是一列(可以是多行),这种子查询称为列子查询
常用的操作符:IN,NOT IN , ANY ,SOME,ALL
in 在制定的集合范围之内,多选一
not in 不在指定的集合范围之内
any 子查询返回列表中,有任意一个满足即可
some 与any等同,使用some的地方都可以使用any
all 子查询返回列表的所有值都必须满足
行子查询
子查询返回的结果是一行(可以是多列),这种子查询称为行子查询
常用的操作符 = <> IN NOT IN
表子查询
子查询返回的结果是多行多列,这种子查询称为表子查询
常用的操作符:IN
事务
事务是一组操作的集合,是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,即这些操作要么同时成功,要么同时失败
业务逻辑之前开启事务,执行完毕后提交事务,如果执行过程报错,则回滚事务,把数据恢复到事务开始之前的状态
默认mysql的事物是自动提交的,也就是说,当执行完一条DML语句时,Mysql会立即稳式的提交事务。
事务操作
控制事物一
select * from account where name=‘张三’;
update account set money = money +1000 where name = ‘李四’;
commit;
rolloback;
事务四大特性
● 原子性:事务是不可分割的 最小操作单元,要么全部成功,要么全部失败。
● 一致性:事务完成时,必须使所有的数据都保持一致状态
● 隔离性:数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立环境下运行‘
● 持久性: 事务一旦提交或者回滚,它对数据库中的数据的改变就是永久的
事务四大特性ACID
并发事务问题
脏读:一个事务读到另一个事务还没有提交的数据
不可重复度:一个事务先后读取同一记录,但两次读取的数据不用,称之为不可重复读。
幻读:一个事务按照条件查询数据时,没有对应的数据行,但是在插入数据时,又发现这行数据已经存在,出现幻读。
事务的隔离级别:
read uncommitted 脏读 不可重复读 幻读
read committed 不可重复读 幻读
repeatable read 幻读
serializable
查看事务隔离级别
select @@transacttion_isolation;
设置事物的隔离级别
set [session | global] transaction isolation level {
read uncommitted | read committed | repeatable read | serializable}
事务的隔离级别越高,数据越安全,但是性能越低。