这几天一直在学数据库(只是初步了解一下),同时也整理了一下笔记。如下:
MySQL是一种关系型数据库。关系型数据库的特点:
关于数据库(database)的基本操作:
有关数据库的基础语法 | 描述 |
---|---|
use 数据库名; | 选择数据库 |
create database 数据库名 (charset 编码格式); | 创建数据库(增) |
drop database 数据库名; | 删除数据库(删) |
alter database 数据库名 (charset 修改后的编码格式); | 修改数据库(改) |
show create database 数据库名; | 查看当前新创建的数据库(查) |
show databases; | 查看所有数据库(查) |
#db1为数据库名(举例声明)
use db1; #选择db1的数据库进行操作
create database db1 charset utf8; #创建一个名为db1的数据库(编码格式为utf8,不写则为默认值)
drop db1; #删除名为db1的数据库
alter database db1 charset gbk; #将db1数据库的编码格式改成gbk
show create database db1; #查看当前新创建的db1数据库
show databases; #查看所有数据库
关于数据表(table)的基本操作:
有关数据表的基础语法 | 描述 |
---|---|
create table 数据表名(数据名,数据类型); | 创建数据表(增) |
drop table 数据表名; | 删除数据表(删) |
alter table 数据表名 modify 数据名 修改后的数据类型; | 修改数据表(改) |
show create table 数据表名; | 查看当前新创建的数据表(查) |
show tables; | 查看所有数据表(查) |
describe(desc) 数据表名; | 查看数据表的结构(查) |
#t1为数据表名 id,name为变量名 int,char(20)为数据类型(举例声明)
create table t1(id int,name char(20)); #创建一个名为t1的数据表
drop table t1; #删除名为t1的数据表
alter table t1 modify id tinyint; #将t1数据表中的id数据的数据类型改成tinyint
show create table t1; #查看当前新创建的数据表t1
show tables; #查看当前数据库中的所有数据表
describe t1; #查看数据表的结构
关于数据记录的基本操作:
有关数据记录的基础语法 | 描述 |
---|---|
insert into 数据表名 (数据名) value (数据值) ; | 创建数据记录(增) |
delete from 数据表名 where 条件; | 删除数据记录(删) |
update 数据表名 set 数据名=新数据值 where 条件; | 修改数据记录(改) |
select 数据名 from 数据表名; | 查看数据表中的数据记录(查) |
#t1为数据表名 id,name为变量名 int,char(20)为数据类型(举例声明)
insert into t1 (id,name) values (1,'wula'); #往数据表t1中添加数据记录
delete from t1 where id = 1; #删除数据表t1中id为1的数据记录
update t1 set id = 2 where id = 1; #将数据表t1中id为1的数据值改成2
select id from t1; #查看数据表t1中id的数据记录
select * from t1; #查看数据表t1中的所有数据记录
MySQL的数据类型大致可以分为三类:数值类型、日期时间类型和字符串类型。
类型名 | 大小 | 描述 |
---|---|---|
数值类型 | ||
TINYINT | 1 byte | 小整数值 |
SMALLINT | 2 bytes | 大整数值 |
MEDIUMINT | 3 bytes | 大整数值 |
INT | 4 bytes | 大整数值 |
BIGINT | 8 bytes | 极大整数值 |
FLOAT | 4 bytes | 单精度浮点值 |
DOUBLE | 8 bytes | 双精度浮点值 |
DECIMAL | * | 小数值 |
日期时间类型 | ||
DATE | 3 bytes | 日期 |
TIME | 3 bytes | 时间 |
YEAR | 1 byte | 年份 |
DATETIME | 8 bytes | 日期加时间 |
TIMESTAMP | 4 bytes | 时间戳 |
字符串类型 | ||
CHAR | 0~255 bytess | 定长字符串 |
VARCHAR | 0~65535 bytes | 变长字符串 |
TINYBLOB | 0~255 bytes | 二进制字符 |
TINYTEXT | 0~255 bytes | 短文本字符串 |
BLOB | 0~65535 bytes | 二进制形式的长文本数据 |
TEXT | 0~65535 bytes | 长文本数据 |
MEDIUMBLOB | 0~16777215 bytes | 二进制形式的中长文本数据 |
MEDIUMTEXT | 0~16777215 bytes | 中长文本数据 |
LONGBLOB | * | 二进制形式的极大文本数据 |
LONGTEXT | * | 极大文本数据 |
其他类型 | ||
enum | * | 枚举(单选) |
set | * | 集合(多选) |
简单使用一下枚举与集合:
#枚举的使用
create table t1(gender enum('female','male','no')); #数据值只能在female,male,no三个中选一个,单选
create table t1(bobby set('football','swim','run')); #数据值只能在footall,swim,run三个里面选,可多选
非空约束(not null):字段可以重复但不能为空
默认值约束(default):字段为空时会有默认值
唯一约束(unique):字段不能重复单但可以为空
主键约束(primary key):字段不能重复且不能为空
外键约束(foreign key):将两个表进行联系。其中被关联表叫做主表,关联表叫做从表
#t1,t2为数据表名 id,name为变量名 int,char(20)为数据类型(举例声明)
#以创建数据表为例子
#非空约束(not null)
create table t1(id int no null,name char(20)); #对id变量加上非空约束
#默认值约束(default)
create table t1(id int default 1,name char(20)); #对id变量加上默认值为1约束
#唯一约束(unique)
create table t1 (id int unique,name char(20)); #对id变量加上唯一性约束
create table t1 (id int,name char(20),unique(id)); #对id变量加上唯一性约束
#主键约束(primary key) 效果:primary key=not null + unique
create table t1 (id int primary key,name char(20)); #建表前对id变量加上主键约束
create table t1 (id int,name char(20),primary key(id)); #建表前对id变量加上主键约束
alter table t1 add primary key (id); #建表后对id变量加上主键约束
#外键约束(foreign key)
#(方法1)将主表与从表的id2与id1之间建立联系。主表中的数据记录被从表引用时,主表中的该记录不可被删除
create table t1 (id1 int,name1 char(20)); #主表
create table t2 (id2 int,name2 char(20),constraint link foreign key(id2) references t1(id1)); #从表
#(方法2)将主表与从表的id2与id1之间建立联系。主表中的数据记录被从表引用时,删除主表中的数据记录时,会相应删除从表中的数据记录
create table t1 (id1 int,name1 char(20)); #主表
create table t2 (id2 int,name2 char(20), #从表
constraint link foreign key(id2) references t1(id1)
on delete cascade on update cascade #同步删除
);
tip:多字段添加约束与联合添加约束的不同
#以唯一约束(unique)为例子
#多字段添加唯一约束:代表数据记录中不能存在id或name相同的数据。(id不同和name不同的数据才能添加)
create table t1 (id int unique,
name char(20) unique
);
#联合添加唯一约束:代表数据记录中不能存在id与name相同的数据。(id不同或name不同的数据也能添加)
create table t1 (id int ,
name char(20) ,
unique(id,name)
);
表与表的关系可分成三种:一对多/多对一,多对多,一对一
先把两张表看做表1与表2,再进行比较判断
一对多/多对一:表1中的一条记录对应表2中的多条记录或表2中的多条记录对应表1中的多条记录
例:游戏里的一个英雄对应多个皮肤
多对多:表1中的一条记录对应表2中的多条记录与表2中的多条记录对应表1中的多条记录
例:一名学生能够选多个课程,一个课程也可以被多个学生选
一对一:表1中的一条记录唯一对应表2中的一条记录与表2中的一条记录唯一对应表1中的一条记录
例:一个人对应一个身份证号,一个身份证号对应一个人
关键字的优先级顺序:from→where→group by→having→distinct→order by→limit
1.from(寻表)
select * from t1;
2.where(约束)
–比较运算符:>,<,>=,<=,<>(不等于),!=
–between a and b 值在a与b之间
–in(a,b,c) 值是a或b或c
–like’ ’ %代表任意多个字符,_代表一个字符
–逻辑运算符and or not
select * from t1 where age > 18; #查找t1表中年龄大于18的数据
select * from t1 where age between 18 and 20; #查找t1表中年龄在18至20之间的数据
select * from t1 where age in(18,20); #查找t1表中年龄为18,20的数据
select * from t1 where name like '黄%'; #查找t1表中姓黄的数据
select * from t1 where age > 18 and name like '黄%'; #查找t1表中年龄大于18且姓黄的数据
3.group by(分组)
聚合函数:
select gender avg(age) from t1 group by gender; #按照性别分组求各分组的平均年龄
4.having(过滤)
select count(id) from t1 group by gender having count(id) > 10; #按照性别分组求出总人数大于10的性别
5.distinct(去重)
select distinct age from t1; #在t1表中求出不重复的年龄(去重)
6.order by(排序)
–asc(升序)
–desc(降序)
select * from t1 order by age asc; #在t1表中按照年龄age升序排序
select * from t1 order by age desc; #在t1表中按照年龄age降序排序
select * from t1 order by age asc,id desc; #在t1表中先按照年龄age升序排序,再按照id降序排序
7.limit(限制)
select * from t1 limit 5; #从头开始获取5个数据(id1~id5)
select * from t1 limit 5,5; #从第5个开始获取5个数据(id6~id10)
多表查询分成三种:多表连接查询,符合条件查询,子查询
多表连接查询
多表连接查询分成内连接,左连接,右连接与外连接。
#数据库t1中有id1数据记录,数据库t2中有id2数据记录(举例声明)
#内连接:(只获取匹配的记录)
select * from t1 inner join t2 on t1.id1 = t2.id2;
#左连接:(只获取左表的所有记录)
select * from t1 left join t2 on t1.id1 = t2.id2;
#右连接:(只获取右表的所有记录)
select * from t1 right join t2 on t1.id1 = t2.id2;
#外连接:(获取所有记录)
select * from t1 left join t2 on t1.id1 = t2.id2 union select * from t1 right join t2 on t1.id1 = t2.id2;
符合条件查询
就是在多表连接查询的条件下加上其他约束
select * from t1 inner join t2 on t1.id1 = t2.id2 where age > 18 ;
子查询
–子查询是将一个查询语句嵌套在另一个查询语句中
–内层查询语句的查询结果,可以为外层查询语句提供查询条件
–子查询中可以包含:IN,NOT IN,ANY,ALL,EXISTS,NOTEXISTS等关键字
–子查询中还可以包含比较运算符:>,<,!=等
select name from t1 where id1 in(select id2 from t2 where age > 18);
select * from t1 where age >(select avg(age) from t1);
在拥有庞大数据量时,很必要建立索引。有索引的查询速度比无索引快。
常见的索引类型:普通索引,唯一索引,主键索引,联合索引
普通索引
特点:快速查找
#普通索引举例
#在建表创建时添加普通索引
create table t1 (id int auto_increment ,
name char(20) not null,
index sy_name(name) #给name添加普通索引
);
#在建表后添加普通索引
create index sy_name on t1(name); #给name添加普通索引
alter table t1 add index sy_name(name) #给name添加普通索引
#删除普通索引(其他的索引也一样)
drop index sy_name on t1; #删除name的普通索引
#查看索引(其他的索引也一样)
show index from t1; #查看t1数据表所添加的索引
唯一索引
特点:快速查找+唯一性
#唯一索引举例
#在建表创建时添加唯一索引
create table t1 (id int auto_increment ,
name char(20) not null,
unique index usy_name(name) #给name添加唯一索引
);
#在建表后添加唯一索引
create unique index usy_name on t1(name); #给name添加唯一索引
alter table t1 add unique index usy_name(name) #给name添加唯一索引
主键索引
特点:加快查找+唯一性+不为空
#主键索引举例(用法和添加主键一样)
#在建表创建时添加主键索引
create table t1 (id int auto_increment primary key, #给id添加主键索引
name char(20) not null,
);
#在建表后添加主键索引
alter table t1 add primary key (id); #给id添加主键索引
联合索引
特点:合并查找速度更快(联合索引的查询速度比索引合并的查询速度快)
#在建表创建时添加联合索引
create table t2 (id int auto_increment ,
name char(20) not null,
index sy_name(id) #给id和name添加联合索引
);
#在建表后添加联合索引
create index sy_name on t1(id,name); #给id和name添加联合索引
对于联合索引(以上述为例),在进行查找时,查找id会使用索引,查找id+name会使用索引,查找name则不会使用索引。
通过explain来查看查询的速度。
explain select * from t1; #得到的查询速度是ALL
查询速度比较:(慢)all
在默认情况下,MySQL会自动管理事务,一条SQL语句独占一个事务。
事务的特点: