数据库
DataBase
,简称为
DB
运行在操作系统上,按一定的数据结构,保存数据的仓库
。是一个电子化的文件柜。
数据永久保存在硬盘中。
数据库管理系统
DataBase Manager System
,简称为
DBMS
通常所说的数据库,是指数据库管理系统,如
MySQL
、
Oracle
等。
是一种操作和管理数据库的大型软件,用于建立、使用和维护数据库。
总结
数据
Data
需要永久保存到数据库中
数据库
DB
是运行在操作系统上的一个软件
数据库管理系统
DBMS
是管理数据库的一个软件
学习数据库就是学习如何使用
DBMS
创建、使用数据仓库来管理数据
常见的数据库管理系统
关系型数据库
关系型数据库是主流的数据库类型。
数据通过
行
row
和
列
column
的形式
(
表格
)
保存。
每
行
称为一条
记录
。
每
列
称为一个
字段
。
字段通常为
Java
中某个类的属性,通过这个类创建的对象,就是一条记录。
如
class Employee
,有员工编号、姓名、部门、工资等属性,
对应数据库中有一个
Employee
表,这个表中有员工编号、姓名、部门、工资等字段。
关系型数据库,数据表直接有关联,能快速地查询出想要的数据。
关系型数据库的特点
优点
易于维护:都是使用表结构存储数据,格式一致
使用方便:
SQL
语句通用,可用于不同关系型数据库
复杂查询:可以通过
SQL
语句在多个表之间查询出复杂数据
缺点
读写性能差,尤其是还是数据的高效读写
固定的表结构,灵活度少欠
高并发读写时,硬盘
I/O
决定了读写速度
非关系型数据库
数据通过对象的形式保存,对象可以是一个键值对、文档、图片等。
非关系型数据库的特点
保存数据的格式多样
对于海量数据的读写性能高
不支持复杂查询
MySQL控制台常用命令
查看所有数据库
show databases;
切换数据库
use 数据库名;
查看当前数据库下的所有表
show tables;
创建一个数据库
create database 数据库名;
删除数据库
drop database 数据库名;
SQL
S
tructrued
Q
uery
L
anguage
结构化查询语言
用于操作关系型数据库的一门语言。可以用来创建、维护数据库和数据。
-- mysql中的注释
操作数据表
1.
创建数据表
create table 表名(
字段名 数据类型 [字段特征],
字段名 数据类型 [字段特征],
...
字段名 数据类型 [字段特征]
)
2.
删除数据表
drop table 表名;
3.
修改数据表
- 删除字段
-
alter table 表名 drop 字段名;
- 对表重命名
-
alter table 旧表名 rename to 新表名;
- 添加新字段
-
alter table 表名 add column 字段名 数据类型 字段特征;
- 修改字段
-
alter table 表名 change 旧字段名 新字段名 数据类型 字段特征;
添加约束
1.
添加非空约束
alter table 表名 change 旧字段名 新字段名 数据类型 not null;
2.
添加主键约束
alter table 表名 add primary key(字段名);
3.
添加唯一约束
alter table 表名 add unique(字段名);
4.
添加默认值约束
alter table 表名 alter 字段名 set default '默认值';
5.
添加外键约束
alter table 从表表名 add foreign key(从表外键字段) references 主表(主表主键字段)
添加约束的操作通常是对已存在的表进行修改和维护时使用。如果是一张新表,最好在创建表的时候设计好约束。
建表的同时添加约束
-- 创建数据库gamedb
create database gamedb;
-- 切换数据库
use gamedb;
-- 创建游戏角色表hero
create table hero(
-- 编号 整型 非空 主键 自增
id int not null primary key auto_increment comment '编号',
-- 姓名 字符串 非空 唯一
name varchar(20) not null unique comment '姓名',
-- 定位 字符串 非空
position varchar(20) not null comment '定位',
-- 性别 字符串 非空 默认男
sex char(1) not null default '男' comment '性别',
-- 价格 整型 非空 默认4800
price int not null default '4800' comment '价格',
-- 上架日期
shelf_date date comment '上架日期'
)
-- 创建战斗表battle
create table battle(
hero_id int not null ,
position varchar(20),
-- 外键 hero_id参考hero表中的id字段
foreign key (hero_id) references hero(id)
)
数据完整性
数据完整性是指数据精确可靠。不能保存无意义或无效的数据。
如不合理的年龄、全为空的记录、重复记录等。
为了保证保存在数据库中的数据是完整数据,就要在设计数据表时添加一些约束或特征来保证数据完整性。
MySQL中常见的数据类型
约束
操作数据
数据的操作,是指数据的增加
create
,修改
update
,查询
read
和删除
delete
。
简称为
CURD
。
数据添加insert
数据添加时,都是整行
(
一条记录
)
添加。不能只给一个字段添加数据。
如果只给某个字段添加数据,实际是修改。
给所有字段赋值
insert into 表名 values('值1','值2'...)
- 表名后无需添加字段名,添加时保证值的顺序和字段的顺序一致
- 遇到自增字段,不能省略不写,要使用0、null或default让其自动填充
- 遇到有默认值的字段,不能省略不写,要使用default让其自动填充默认值
- 遇到允许为空的字段,不能省略不写,要使用null让其设置为空
给指定字段赋值
insert into 表名(字段1,字段2...) values('值1','值2'...)
- 没有默认值的非空字段必须要写出来
- 表名后的字段顺序要和值的顺序一致
批量添加
可以用一个
insert into
语句添加多条记录
insert into 表名[(字段1,字段2)] values
('值1','值2'...),
('值1','值2'...),
...
('值1','值2'...)
- 可以省略表名后的字段名
- 值的顺序和字段的顺序一致
- 如果一次添加多条记录时,优先使用批量添加,效率更高
数据修改update
修改单个字段的所有值
update 表名 set 字段 = 值;
修改多个字段的所有值
update 表名 set 字段1 = '值',字段2 = '值'...
根据条件修改(where子句)
update 表名 set 字段 = '值' where 条件
指定值
update 表名 set 字段 = '值' where 字段 = '值'
指定范围
- 使用>、<、>=、<=表示范围,使用and、or、&&、||将多个条件关联
-
update 表名 set 字段 = '值' where 字段
- 使用"字段 between 值1 and 值2"表示字段在闭区间[值1,值2]
-
update 表名 set 字段='值' where 字段 between 值1 and 值2
- 使用!=或<>表示不等于
-
update 表名 set 字段='值' where 字段<>值
指定集合
在某个集合中
in
update 表名 set 字段='值' where 字段 in ('值1','值2'...)
不在某个集合中
not in
update 表名 set 字段='值' where 字段 not in ('值1','值2'...)
空值
使用
is null
表示空
update 表名 set 字段 = '值' where 字段 is null
使用
is not null
表示非空
update 表名 set 字段 = '值' where 字段 is not null
模糊查询
-- 字段 like '%娜%'
-- 带有'娜'字
-- 字段 like '张%'
-- ‘张’字开头
-- 字段 like '%儿'
-- ‘儿’字结尾
-- 字段 like '%瑞_'
-- 倒数第二个字为‘瑞’
-- 字段 like '___'
-- 3个字
update 表名 set 字段 = '值' where 字段 like ‘%文字%’
数据删除delete
数据删除是删除一条或多条记录。
删除所有
delete from 表名;
-- 或
truncate table 表名;
delete
会保留自增列删除前的值,删除后再添加时,自动从删除前的值开始自增
truncate
会重置自增列的值。效率更高
如果要删除主从关系且设置了外键的表中的数据,如果从表中有数据,不能直接删除主表中相关数
据,先删除从表中的数据后,才能删除主表中的数据
条件删除
delete from 表 where 条件
删除时的条件同修饰时的条件语句
数据查询select
查询所有字段
select * from 表名;
查询指定字段
select 字段名1,字段名2... from 表名;
字段重命名
select 字段1 as '重命名',字段2 '重命名'... from 表名;
查询指定条数
-- 查询前N条记录
select * from 表名 limit N;
-- 查询从索引N开始的M条记录
select * from 表名 limit N,M;
-- 每页显示size条,第page页
select * from 表名 limit (page-1)*size,size
去重复
select distinct 字段名 from 表名;
条件查询
where
子句,语法同修改、删除时的
where
select * from 表名 where 条件;
排序
select * from 表名 where 条件 order by 排序字段 [ASC/DESC],排序字段 [ASC/DESC]...
- 排序可以是升序或降序
- 默认不写是升序asc
- 降序需要写desc
- 排序时如果有条件,where条件写在表名之后,排序之前
- 多字段排序时,在order by之后写多个字段及排序规则,用逗号隔开
- 按字段顺序优先排序
统计函数(聚合函数)
select 统计函数(字段名) from 表名;
数学相关函数
字符串相关函数
时间相关函数
分组
select 分组字段,统计函数 from 表名 group by 分组字段
按指定的字段进行分组,会将该字段值相同的记录归纳到同一组中。
分组通常配合统计函数使用。
如果统计函数作为条件,不能写在
where
之后,要写在
having
之后,
having
子句放在分组之后。
-- 按图书作者分组,查询平均价格大于50的信息
select book_author,avg(book_price) from book_info
group by book_author
having avg(book_price)>50
group_concat()函数
将分组后的数据拼接成字符串。
group_concat(字段1或字符串,字段2或字符串...)
select group_concat(字段1,字段2...) from 表名 group by 分组字段
-- 根据图书类型分组,查看每组下的图书名和作者
select group_concat(book_name,'--',book_author) from book_info group by type_id