mysql学习——02 约束、查询

一、完整性约束条件

1 概念

在执行DML操作时,对表中的数据进行一种强制性校验规则。这样可以保证数据的完整性、安全性、商业逻辑性,也简称约束。

2 非空约束

not null,简称NN
表示设置了非空约束的字段里值不能为空

建表: create table tbname(colname type not null,...);
建表后:alter table tbname modify colname type not null;

3 唯一性约束

unique,简称UK
表示设置了唯一性约束的字段的值不能重复,但可以为null

建表:create table tbname(colname type unique,...);
建表后:alter table tbname modify colname type unique;

4 主键约束

primary key
非空和唯一性的组合形式。要求字段非空且唯一。每张表只能有一个主键

建表:create table tbname(colname type primary key,...);
create table tbname(colname1 type1,colname2 type2,...,primary key(colname1));
建表后:alter table tbname add CONSTRAINT pk_id primary key(id);
tips:尽可能在单列上设置,设置的字段尽可能的没有商业价值
自增长序列:auto_increment 通常与主键约束一起使用,用于给此字段自动赋值,
值的特点是连续自增的序列,默认从1开始
create table tbname(colname type primary key auto_increment,...);

5 外键约束

foreign key,简称FK
表示设置外键约束的字段B的值依赖于某一个字段A的值
不支持列级写法
建表
create table tbname(colname1 type1,colname2 type2,...,CONSTRAINT fk_col_col foreign key(colname) references tbname(colname));
建表后
alter table tbname add CONSTRAINT consname foregin key(id) references tbname(colname);

6 检查性约束

check,简称CK
表示设置有检查性约束的字段的值必须符合检查条件
tips:mysql的检查性约束无效。语法通过。
用枚举替换

二、基本查询语句

1.基本结构

select ... from ... where ... group by ... having ... order by 
执行顺序:from->where->group by->having->select->order by

2.列别名、表别名

1.通配符:*,表示所有的字段		select * from tbname
2.指定字段进行查询			select colname1,colname2 from tbaname
3.使用列别名		select col1 [as] nickname1,col2 nickname2 from tbname
4.使用表别名		select tbname.id,nickname.name from [as] tbname nickname

3.where子句

4.group by子句

分组查询,将表中某些记录按照某个/某些字段的值进行分组
通常在分组查询时,都会使用到聚合函数(分组函数)
比如:max(colname) min(colname) sum(colname) 
avg(colname) :ifnull(colname,val)如果colname为null就将val赋值给colname
count(colname) 统计每一组中的记录数目。count(*)
tips:聚合函数会忽略掉字段里的空值,不会统计空值
分组查询时,一般情况下,分组字段放在select子句中,其他子句不能放在select子句中
查询特点

5.having子句

是对分组查询进行再一次过滤筛选,having子句后面是条件

6.order by子句

用于对已选择的数据根据需求的字段进行排序(asc 升序/desc 降序)
order by colname [asc / desc]

7.去重查询

关键字:distinct。放在select关键字之后

8.分页查询

关键字limit
limit m,n 通常放在order by子句后
m:表示从第m条记录开始
n:表示查询n条记录

三、关联查询基础

1 概念

实际应用中,我们所需要的数据不仅仅只在一张表中,而是在多张表中存在。
因此我们在查询时,需要进行多表查询,也叫关联查询

2 笛卡尔积

在进行多表查询时,表A有m条记录,表B有n条记录,表A中的每条记录都会与表B中的每条记录
进行匹配组合成一条新纪录。最终会有m*n条记录,m*n就是笛卡尔积。通常情况下笛卡尔积没有实际意义。

3 等值连接

多表查询时,使用两张张表中有关系的字段进行等值匹配。就是等值连接

4 内连接

是等值连接的另外一种写法
from tbname1 join tbname2 on 关联条件

5 外连接

两张表,有一张表A中的数据全部显示,另外一张表B的数据只显示满足条件的数据。
表A我们称之为驱动表,表B称之为从动表

左外连接:左边为驱动
from tbnme1 left join tbname2 on

右外连接:右边为驱动
from tbnme1 right join tbname2 on

6.自连接

外连接的特殊情况,即两张表示同一张表,也称之为自连接

四、高级关联查询

1 概念

在一个查询语句A中所需要的数据不是直观体现在表中的,而是需要通过另外一个查询语句B获取的结果。
这种查询成为关联查询
A为主查询,B为子查询
案例1:查询工资大于smith的工资的所有员工信息

分析:  
        第一步:先查询smith的工资,假如是num
         select sal from emp where ename = 'smith'
        第二步:再查询工资大于num的所有员工信息
         select * from emp where sal >num;
        第三步:组合:
         select * from emp where sal >(select sal from emp where ename = 'smith');

2 子查询语句在where中

3 子查询语句在from子句中

4 子查询语句在having子句中

5 子查询语句在select子句中

你可能感兴趣的:(mysql)