MySQL数据库总结

Posted Zeker62

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL数据库总结相关的知识,希望对你有一定的参考价值。

文章目录

DDL操作数据库、表

操作数据库

查看数据库

show databases;

查询创建数据库mysql的字符集

show create database mysql;

创建数据库

create database db1; -- 创建db1数据库

show create database db1; -- 查看db1数据库的字符集

create database if not exists db2 -- 如果不存在就创建db2,判断操作

create database db3 character set gbk; -- 将字符集设置成gbk编码
show create database db3

create database if not exists db4 character set gbk; -- db4不存在的情况下,创建数据库db4,同时设置编码为gbk

修改数据库

alter database db3 character set utf8; -- 不能写成utf-8

删除数据库

drop database db3;

drop database if exists db4;

使用数据库

select database(); -- 查询当前正在使用的数据库名称

use db1; -- 使用数据库db1

操作表

查询表(use、show)

use db1;

show tables; -- 显示当前数据库的所有表的名称

desc db1; -- 查询当前表的结构

数据类型

  • int 整数类型
  • double(a,b) 浮点数类型,浮点数长a,小数点保留到b为
  • date 日期类型,只包含年月日 yyyy-MM-dd
  • datetime 日期类型,包含年月日时分秒 yyyy-MM-dd HH:mm:ss
  • timestamp 时间戳类型 包含年月日时分秒 yyyy-MM-dd HH:mm:ss。如果不给这个字段赋值,或为null,那么默认使用当前系统的时间
  • varchar(a) 字符串类型,最大为a个字符长度
  • 详细内容:菜鸟教程-Mysql数据类型

创建表(create)

create table student(
	id int,
	name varchar(32),
	age int,
	score double(4,1), -- 100.0
    birthday date,
    insert_time timestamp
);

复制表(like)

create table stu like student; -- 复制student表

删除数据表(drop table)

drop table stu;

drop table if exists stu;

修改表(alter)

alter table student rename to stu; -- 将student表重命名

show create table stu;
alter table stu character set utf8; -- 修改表的字符集

alter table stu add gender varchar(10); -- 添加名为gender的列

alter table stu change gender sex varchar(20); -- 修改名为gender的列名为sex,并修改数据类型
alter table stu modify sex varchar(10); -- 只改类型,不改名称

alter table stu drop sex; -- 删除表中的sex列

DML 增删改表中数据

添加数据(insert)

insert into stu(id,name,age) values(1,'张无忌',18); -- 将数据插入到表当中

INSERT INTO stu VALUES(1,'Tom',17,99.5,NULL,NULL); -- 省略列名的添加方式

INSERT INTO stu VALUES(3,'Bob',19,88.5,"1993-11-11",NULL); -- 除了数字类型,其他类型都需要用单引号或者双引号引用起来。

删除数据(delete、truncate)

DELETE FROM stu WHERE id=3; -- 删除列名为id,值为3的一行记录

DELETE FROM stu; -- 删除stu表中所有的数据,数据量大的时候开销大,有多少条记录就会执行多少次删除操作。

TRUNCATE TABLE stu; -- 直接删除stu表,然后再创建一个不含数据但结构一样的stu表,数据量大的时候开销小

修改数据(update)

UPDATE stu SET age=22 WHERE id=2; -- 修改id=2的那一行的age属性值

UPDATE stu SET age=18 ,score=100 WHERE id=3; -- 同时修改两个数据

UPDATE stu SET age=20; -- 不加限制条件,则会修改age字段的所有数据都为20

DQL查询表中的记录

基础查询(select、DISTINCT、IFNULL()函数)

select * from stu;

SELECT NAME,age FROM stu; --两列

SELECT DISTINCT age FROM stu; -- distinct 去除重复的结果集

SELECT NAME,math,english,math+english FROM stu; -- 两列数值可以直接相加,如有null参加运算,计算结果都为null

SELECT NAME,IFNULL(math,0),IFNULL(english,0),math+english FROM stu; -- 可以用ifnull 这个函数来进行null值判断,如果为null,那么这个数据就会当成0来计算

SELECT NAME,IFNULL(math,0) AS 数学,IFNULL(english,0) AS 英语,math+english AS 总分 FROM stu; -- 使用as 进行起别名

条件查询(> < = ! & |、between and、or、and、in)

-- 比较运算符
SELECT * FROM stu WHERE math>80;
SELECT * FROM stu WHERE math=80;
SELECT * FROM stu WHERE math>=80;
SELECT * FROM stu WHERE math!=80;
SELECT * FROM stu WHERE math<>80; -- 不等号

-- 逻辑运算符
SELECT * FROM stu WHERE math<=80 && math>90; -- 不推荐
SELECT * FROM stu WHERE math<=80 and math>90;
SELECT * FROM stu WHERE math BETWEEN 80 AND 90; -- 在80和90之间,包括80和90

SELECT * FROM stu WHERE math=80 || math=90;-- 不推荐
SELECT * FROM stu WHERE math=80 OR math=90 OR math=100; -- 或者条件
SELECT * FROM stu WHERE math IN (80,90,100); -- 或者条件的简写

对null操作(is null、is not null)

-- 对null操作
SELECT * FROM stu WHERE birthday=NULL; -- 不正确,null不能使用比较运算符判断,应该用is
SELECT * FROM stu WHERE birthday IS NULL;
SELECT * FROM stu WHERE birthday IS NOT NULL;

模糊查询(%、_)

SELECT * FROM stu WHERE NAME LIKE '张%'; -- 查询名字第一个字是张
SELECT * FROM stu WHERE NAME LIKE "_无%"; -- 查询名字第二字是无的人
SELECT * FROM stu WHERE NAME LIKE "___"; -- 查询名字是三个字的人
SELECT * FROM stu WHERE NAME LIKE "%无忌%"; -- 查询名字包含无忌的人

排序查询(order by ASC\\DESC)

SELECT * FROM stu ORDER BY math; -- 默认升序 asc
SELECT * FROM stu ORDER BY math ASC;
SELECT * FROM stu ORDER BY math DESC; -- 降序

SELECT * FROM stu ORDER BY math ASC ,english ASC;-- 按照数学成绩排名,数学成绩一样,就按照英语成绩排序,都是升序。当第一个条件值排序一样的时候,才会去判断第二个条件

聚合函数(count()、max()、min()、sum()、avg())

-- 将一列数据作为一个整体,做纵向计算

SELECT COUNT(NAME) FROM stu; -- 计算name列中的属性个数
-- 注意:聚合函数会排除null值,解决方法:
SELECT COUNT(*) FROM stu;  -- 使用*计算
SELECT COUNT(id) FROM stu; -- 使用不为空的主键
SELECT COUNT(IFNULL(birthday,0)) FROM stu; -- 把null值替换成0

select max(math),min(math),avg(math) from stu; -- 计算数学成绩的最大值,最小值,以及平均成绩
SELECT SUM(math) FROM stu; -- 计算数学总成绩
SELECT SUM(math,english) FROM stu; -- 报错,不能两个列进行操作

分组查询(group by … having…)

SELECT age,AVG(math) FROM stu GROUP BY age; -- 不同年龄的数学平均分
SELECT age,COUNT(id) FROM stu GROUP BY age; -- 查询不同年龄的人数分别有多少
SELECT age,AVG(math),COUNT(id) FROM stu GROUP BY age;

SELECT age,AVG(math) FROM stu  WHERE math<90 GROUP BY age ; -- 查询成绩低于90分的不同年龄段的平均成绩
SELECT age,AVG(math) FROM stu  GROUP BY age HAVING age>18 ; -- 分组之后,年龄要大于18
  • where 和 having的区别
    • 位置不同,where 在分组之前限定,如果不满足结果,则不参与分组。having在分组之后确定,如果不满足结果则不显示出来
    • where后面不能跟聚合函数,having后面可以跟聚合函数

分页查询(limit)

SELECT * FROM stu LIMIT 0,2; -- 从0开始查,查三条记录
SELECT * FROM stu LIMIT 2,2; -- 从第3条开始,查两条
-- 【开始的索引】=【当前的页码-1】*【每页显示的条数】
-- 最后一页有多少条显示多少条,不会报错

limit操作是一个MySQL方言,只能在MySQL数据库中用

约束

约束就是对表中数据进行限定,保证数据的正确性,有效性和完整性

分类:

  • 主键约束
  • 非空约束
  • 唯一约束
  • 外键约束

非空约束(not null)

某一列的值不能为空

-- 创建表添加非空约束
create table stu(
	id int,
	name varchar(20) not null -- name为非空
);
ALTER TABLE stu MODIFY NAME VARCHAR(20); -- 取消(删除)非空约束
ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL; -- 额外添加非空约束

唯一约束(unique)

某一列的值不能重复

CREATE TABLE stu(
	id INT,
	phone_number VARCHAR(20) UNIQUE -- 唯一约束
	-- 手机号不能重复
);

唯一约束可以有null值,但是只有一条记录可以有null

-- 删除唯一约束
ALTER TABLE stu MODIFY phone_number VARCHAR(20); -- 不能删除

ALTER TABLE stu DROP INDEX phone_number; -- 正确删除
ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE; -- 添加唯一约束,如果此时数据不满足列的unique,就会报错

主键(primary key)

非空且唯一,一张表只能有一个字段为主键

CREATE TABLE stu(
	id INT PRIMARY KEY, -- 主键
	NAME VARCHAR(20)
);
-- 删除主键
ALTER TABLE stu MODIFY id INT;  -- 不起作用

ALTER TABLE stu DROP PRIMARY KEY; -- 正确删除

自动增长(auto_increment)

-- 自动增长,必须是数字类型
CREATE TABLE  stu(
	id INT PRIMARY KEY AUTO_INCREMENT, -- 给id添加自动增长主键约束
	NAME VARCHAR(20)
);

INSERT INTO stu VALUES(NULL,'sss'); -- 此时会读取上一条id的值,并将此时的id为上一个id+1

-- 删除自动增长
ALTER TABLE stu MODIFY id INT; -- 主键并不会被删除
-- 添加自动增长
ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;

外键约束(FOREIGN KEY … REFERENCES …)

看一段数据:

CREATE TABLE emp(
	id INT PRIMARY KEY AUTO_INCREMENT,
	NAME VARCHAR(30),
	age INT,
	dep_name VARCHAR(30),
	dep_location VARCHAR(30)
);
SHOW TABLES;
INSERT INTO emp(NAME,age,dep_name,dep_location) VALUES('张三',18,'研发部','广州');
INSERT INTO emp(NAME,age,dep_name,dep_location) VALUES('李四',20,'研发部','广州');
INSERT INTO emp(NAME,age,dep_name,dep_location) VALUES('王五',21,'研发部','广州');
INSERT INTO emp(NAME,age,dep_name,dep_location) VALUES('宋白',18,'销售部','深圳');
INSERT INTO emp(NAME,age,dep_name,dep_location) VALUES('张成',24,'销售部','深圳');
INSERT INTO emp(NAME,age,dep_name,dep_location) VALUES('孙七',23,'销售部','深圳');
    id  name       age  dep_name   dep_location  
------  ------  ------  ---------  --------------
     1  张三          20  研发部        广州        
     2  李四          20  研发部        广州        
     3  王五          21  研发部        广州        
     4  宋白          18  销售部        深圳        
     5  张成          24  销售部        深圳        
     6  孙七          23  销售部        深圳       

数据存在冗余,销售部一定在深圳,研发部一定在广州

解决方案,分成两张表,一张写员工,一张写部门

-- 部门表
CREATE TABLE department(
	id INT PRIMARY KEY AUTO_INCREMENT,
	dep_name VARCHAR(20),
	dep_location VARCHAR(20)
);
-- 员工表
CREATE TABLE employee(
	id INT PRIMARY KEY AUTO_INCREMENT,
	NAME VARCHAR(20),
	age INT,
	dep_id INT
);
SHOW TABLES;
DESC employee;
DESC department;


-- 添加两个部门
INSERT INTO department VALUES(NULL,'研发部','广州'),(NULL,'销售部','深圳');

INSERT INTO employee(NAME,age,dep_id) VALUE('张三',20,1);
INSERT INTO employee(NAME,age,dep_id) VALUE('李四',20,1);
INSERT INTO employee(NAME,age,dep_id) VALUE('王五',21,1);
INSERT INTO employee(NAME,age,dep_id) VALUE('宋白',18,2);
INSERT INTO employee(NAME,age,dep_id) VALUE('张成',24,2);
INSERT INTO employee(NAME,age,dep_id) VALUE('孙七',23,2);
SELECT * FROM employee;
SELECT * FROM department;

    id  name       age  dep_id  
------  ------  ------  --------
     1  张三          20         1
     2  李四          20         1
     3  王五          21         1
     4  宋白          18         2
     5  张成          24         2
     6  孙七          23         2
     
    id  dep_name   dep_location  
------  ---------  --------------
     1  研发部        广州        
     2  销售部        深圳        

带来问题,两个表不能关联,需要添加外键

-- 部门表
CREATE TABLE department(
	id INT PRIMARY KEY AUTO_INCREMENT,
	dep_name VARCHAR(20),
	dep_location VARCHAR(20)
);
-- 员工表
CREATE TABLE employee(
	id INT PRIMARY KEY AUTO_INCREMENT,
	NAME VARCHAR(20),
	age INT,
	dep_id INT,
	CONSTRAINT emp_dept_fk FOREIGN KEY (dep_id) REFERENCES department(id) -- 外键,dep_id和department表中的id关联了
);

-- 删除外键
ALTER TABLE employee DROP FOREIGN KEY emp_dept_fk;

-- 添加外键
ALTER TABLE employee ADD CONSTRAINT emp_dept_fk FOREIGN KEY (dep_id) REFERENCES department(id);

修改数据库引擎(ENGINE=INNODB)

如果外键不起作用,数据库表的默认引擎为MyISAM,这个引擎不支持外键,需要换成innoDB即可。

解决方法:

  1. 修改表的引擎
SHOW TABLE STATUS LIKE 'employee'; -- 查看数据表引擎

ALTER TABLE employee ENGINE=INNODB;
  1. 新建表时直接给值
CREATE TABLE department(
	id INT PRIMARY KEY AUTO_INCREMENT,
	dep_name VARCHAR(20),
	dep_location VARCHAR(20)
)ENGINE = INNODB; -- 修改引擎
-- 员工表
CREATE TABLE employee(
	id INT PRIMARY KEY AUTO_INCREMENT,
	NAME VARCHAR(20),
	age INT,
	dep_id INT,
	CONSTRAINT dep_id_fk FOREIGN KEY(dep_id) REFERENCES department(id) -- 外键,dep_id和department表中的id关联了
)ENGINE = INNODB; -- 修改引擎

级联操作(ON UPDATE CASCADE)

外键的约束要更改相应的值就特别麻烦。

级联操作可以做到只要更改一处,相关联的就会接着更改

-- 添加外键,设置级联更新
ALTER TABLE employee ADD CONSTRAINT emp_dept_fk FOREIGN KEY(dep_id) 

以上是关于MySQL数据库总结的主要内容,如果未能解决你的问题,请参考以下文章

mysql三表查询sql语句

sql server查询问题。

Java面试题总结之数据库与SQL语句

mysql中给查询结果添加序号列

SQL的嵌套问题

数据库查询语句