(MySQL)SQL复习笔记

常用的服务型数据库Oracle、MySQL、postgresql等等都是关系型数据库,文档型数据库SQLite是用于移动端(手机、pad等等)存储数据

E-R关系模型

entry-relationship:实体-关系,一个实体转化成一个数据库中的表,关系包括一对一、一对多、多对多。关系转换数据库表中的一个列,在关系型数据库中一行就是一个对象

三范式

列不可拆分、唯一标识(主键必须)、引用主键(关系表示时只能引用主键)

数据完整性

1.数据类型:数字(int、decimal小数)、字符串(char、varchar、text大文本)、日期(datetime日期和时间)、布尔(bit二进制数据)

2.约束:主键(primary key)、非空(not null)、唯一(unique)、默认(default)、外键(foreign key)。表中只有一列为主键,唯一约束是表中有多个唯一约束列

3.逻辑删除:在列表中添加一列作为删除标记(本质就是修改操作update),如isDelete、DeleteFlag

数据库操作

1.创建数据库:create database 数据库名 charse=utf8;

2.删除数据库:drop database 数据库名

3.选择数据库:use 数据库名

4.列出所有数据库:show databases

表操作

1.列出所有表:show tables

2.新增表:create table 表名(列及类型)

create table s(id int auto_increment primary key),列id为int类型、自增长、主键

sname varchar(10) not null,sname字段为长度限制为10的字符

);

3.修改表:alter table 表名 add|change|drop 列名 类型

新增列、只能修改列的类型、删除列

4.删除表:drop table 表名

添加主键、外键

create table a(id int auto_increment primary key),列id为int类型、自增长、主键

sname varchar(10) not null,sname字段为长度限制为10的字符

foreign  key(sid) reference s(id));列sid为外键关联表s的列id

插入语句

1.全列插入:insert  into 表名 values(...) 赋值顺序和表中列顺序必须一致

2.缺省插入:insert  into 表名(列1、列2...) values(值1、值2...)

3.同时插入多条数据:insert  into 表名 values(...),(...),(...)...

insert  into 表名(列1、列2...) values(值1、值2...),(值1、值2...),(值1、值2...)...

修改语句

update 表名 set 列1=值1,... where 条件

删除语句

delete from 表名 where 条件

备份和恢复

1.备份:mysqldump -u root -p 数据库名 > d:\db.bak

2.恢复:mysql -u root -p 数据库名 < d:\db.bak

恢复之前需要先创建一个数据库

查询

1.全表查询:select * from 表名

2.去重复行查询:select distinct 列名  from 表名

3.条件查询:select * from 表名 where 条件

(以下放在where关键字后面做查询条件)

4.逻辑运算符:and、or、not

5.比较运算符:=(等于)、>(大于)、>=(大于或等于)、 <(小于)、<=(小于或等于)、!=或<>(不等于)

6.模糊查询:like、%(表示任意一个或多个字符)、_(表示任意一个字符,可以用__匹配任意2个字符)

7.范围查询:in(值1,值2,...)在多个不连续的之中匹配

between  ... and ...在一个连续范围内匹配

8.空判断

(1)null与空字符串不同

(2)判断是否为空 is null

查询条件优先级

小括号、not、比较运算符、逻辑运算符

and比or先运算,可以使用小括号提高运算等级

between 后面第一个and 被该关键字匹配

聚合函数

根据多行进行统计,生成的统计结果集,常用的5个聚合函数

1.count()统计行数,括号中写*或者列名结果相同:select  count(*)  from  表名

2.max()列最大值:select  max(列命名)  from  表名

3.min()列最小值:select  min(列命名)  from  表名

4.avg()列平均值:select  avg(列命名)  from  表名

5.sum()所有列的和:select  sum(列命名)  from  表名

分组

按字段分组:group by

select  列1,列2,聚合...  from 表名 group  by 列1,列2,列3,...

如:select  gender as 性别,count(*)...  from students group  by gender

分组后数据筛选

对分组后的结果集进行筛选:having

select  列1,列2,聚合...  from 表名 group  by 列1,列2,列3,... having 列1,...聚合...

如:select  gender as 性别,count(*)...  from students group  by gender having gender=1

select  gender as 性别,count(*)...  from students group  by gender having count(*)>2

(where是对from后面的结果集进行筛选,having是对分组后的结果集进行筛选)

分页

1.select  *  from  表名  limit start,count

从start开始,获取count条数据,start的索引从0开始

2.每页显示m条数据,当前显示第n页,页数从1开始传:

select  *  from  表名  limit  (n-1)*m,m

级联操作

1.限制(restrict):删除有外键关联的数据时,如果id存在则抛出异常

2.级联(cascade):主表记录删除所有关联记录都被删除

3.set  null:将外键设置为空

4.no  action:什么都不坐

逻辑删除可以解决外键删除问题

链接查询

1.表A  inner  join  表B:表A与B匹配的行会出现在结果中,没有匹配到的数据不显示,无论表A和B的前后顺序得到相同结果

2.表A  left  join  表B:表A与B匹配的行会出现在结果中,外加表A中独有的数据,未对应B的字段使用null填充

3.表A  right  join  表B:表A与B匹配的行会出现在结果中,外加表B中独有的数据,未对应A的字段使用null填充

自关联

当前表的一个字段引用自己的主键:

create table areas(id int auto_increment primary key),列id为int类型、自增长、主键

title varchar(50) not null,

foreign  key(pid) reference areas(id));列pid关联当前表的id

视图

复杂查询的结果需要多次使用时,可以封装成一个视图

存在学生students、成绩scores、科目subject三个表

create view  v_stu_sub_sco as

select  student.*,subject.title,scores.score  from scores

inner join students on scores.stuid=students.id

inner join subject on  scores.subid=subject.id

where  student.isDelete=1 and subject.isDelete=0

自关联查询

select *  from  areas as sheng  where title='山西省'

select  *  from areas as shi

以上两条语句join链接查询:

select sheng.id as sid,sheng.title as stitle,shi.id as shiid,shi.title as shititle  from  areas as sheng

inner  join areas as shi on sheng.id=shi.id

where  sheng.pid  is  null  and sheng.title='山西省'

limit  0,100

查询出山西省中的所有市的信息

一次查询性能测试

set   profiling=1

执行SQL语句

show profiles

事物

当一个业务逻辑需要多个sql完成时,如果其中某条sql出错,则整个操作回滚

使用事物保障一个业务的完整性:原子性(业务不可再拆分)、一致性(执行的结果必须一致,顺序不同结果相同)、隔离性(不会授其他事物影响执行结果)、持久性(对于任意已提交的事物,系统必须保证数据完整不丢失)

你可能感兴趣的:((MySQL)SQL复习笔记)