华清远见-重庆中心-数据库阶段总结

数据库

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'...)

  • 表名后无需添加字段名,添加时保证值的顺序和字段的顺序一致
  • 遇到自增字段,不能省略不写,要使用0nulldefault让其自动填充
  • 遇到有默认值的字段,不能省略不写,要使用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 字段 = '值'

指定范围

  • 使用><>=<=表示范围,使用andor&&||将多个条件关联
  • 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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值