约束、表查询_常用函数

简单DDL

DDL : Data Definition Language 数据库定义语言

涉及的关键字 : create drop alter

昨天我们讲了表的创建和删除,可以规定表名是什么,可以有多少列,数据类型分别是什么,那么比如创建错了,想更改,就要涉及到一个关键字 alter

比如更改表名

alter table 表名 rename 新表名;

如 alter table teacher rename t_teacher;

更改字段名

alter table 表名 change 列名 新列名 数据类型;

更改表的列名 和 数据类型 当然数据类型可以不改,但是必须得写,

如 alter table t_teacher change name teacher_name varchar(20);

添加字段

alter table 表名add 列名类型;

如 alter table t_teacher add birthday datetime; 默认添加到尾部

alter table t_teacher add birthday datetime after teacher_name; 把列添加到指定列的后面

alter table t_teacher add sex2 char(2) first; 添加到第一列,需要把表关掉,刷新一下,再打开才能显示出来

删除字段

alter table 表名 drop 列名;

如 alter table t_teacher drop birthday;

更改字段类型(尽量不要更改)

alter table 表名 modify 列名 新数据类型;

如 alter table t_teacher modify sex2 varchar(20);

alter table 表名 modify 列名 数据类型 comment '该列的注释说明';  更改类型的同时,还能添加注释说明

查看建表语句

show create table 表名;

DDL增强

主键设置可以划分为两种

第一种 : 创建表语句时,添加主键约束

第二种 : 创建表完成之后,通过alter添加主键约束

下面是使用方式

第一种 : 创建表语句时,添加主键约束

 create table person(

        id int ,

        name varchar(100),

        income decimal(18,2),

        primary key (id,name)

    );

上面代码设置了两个主键

 create table person1(

        id int ,

        name varchar(100),

        income decimal(18,2),

        primary key (id)

    );

上面代码设置了一个主键

如果只有一列主键,也可以直接写在字段后面

 create table person2(

        id int primary key,

        name varchar(100) ,

        income decimal(18,2)

      );

第二种 : 创建表完成之后,通过alter添加主键约束

语法 :  alter table 表名 add primary key(列名,列名...);

create table person3(

        id int ,

        name varchar(100),

        income decimal(18,2)

      );

比如要对person3表添加id列主键

 alter table person3 add primary key(id);

主键自增

设置自增的两种方式 :

第一种 : 建表时,添加自增

第二种 : 创建表之后,添加自增

下面是使用方式

第一种 : 建表时,添加自增

create table person4(

id int auto_increment ,

name varchar(200),

 primary key(id)

);

测试语句 :

insert into person4(name)values('测试');

并未输入id的值,但是可以自动填充

第二种 : 创建表之后,添加自增

语法 : alter table 表名modify 主键列名 类型 auto_increment;

create table person5(

id int ,

name varchar(200),

 primary key(id)

);

alter table person5 modify id int auto_increment;

测试语句 :

insert into person5 (name)values('测试');

并未输入id的值,但是可以自动填充

设置自增的起始值

语法 : alter table 表名auto_increment=值;

create table person6(

id int auto_increment ,

name varchar(200),

 primary key(id)

);

alter table person6 auto_increment=10000;

测试语句 :

insert into person6 (name)values('测试');

Id值从10000开始

设置外键有两种方式 :

第一种 : 创建表时添加外键约束

第二种 : 创建完表之后,添加外键约束

下面是使用方式

第一种 : 创建表时添加外键约束

create table teacher(

    id int ,

    name varchar(20),

    primary key (id)

);

create table student (

    id int ,

    name varchar(20),

    teacher_id int ,

    primary key (id),

    foreign key (teacher_id) references teacher(id)

);

注意 : 引用student中添加外键列,指向teacher表,所以必须先创建teacher表才行

测试语句

添加一个讲师

insert into  teacher (id,name) values(1,'张老师');

添加一个学生小明,学生通过teacher_id可以指向张老师

insert into  student (id,name,teacher_id) values(1,'小明',1);

添加一个学生小红,teacher_id没有设置值

insert into  student (id,name) values(2,'小红');

添加一个小黑,teacher_id指向一个不存在的讲师,报错

insert into  student (id,name,teacher_id) values(3,'小黑',2);

第二种 : 创建完表之后,添加外键约束

create table student1 (

    id int ,

    name varchar(20),

    teacher_id int,

    primary key (id)

);

create table teacher1(

    id int ,

    name varchar(20),

    primary key (id)

);

语法 : alter table 表名 add foreign key (外键列列名) references 指向的表名 (主键列列名);

alter table student1 add foreign key (teacher_id) references teacher1 (id);

测试语句

添加一个讲师

insert into  teacher1 (id,name) values(1,'张老师');

添加一个学生小明,学生通过teacher_id可以指向张老师

insert into  student1 (id,name,teacher_id) values(1,'小明',1);

添加一个学生小红,teacher_id没有设置值

insert into  student1 (id,name) values(2,'小红');

添加一个小黑,teacher_id指向一个不存在的讲师,报错

insert into  student1 (id,name,teacher_id) values(3,'小黑',2);

唯一约束unique

设置unique约束有两种方式 : 

第一种 : 创建表时,添加unique约束

第二种 : 创建表之后,添加unique约束

下面是使用方式

第一种 : 创建表时,添加unique约束

   create table temp (

    id int ,

    `name` varchar(20),

    unique(id)

);

   create table temp (

    id int  unique ,

    `name` varchar(20)

);

添加一条没有id的数据

insert into temp (name)values('张三');

再添加一条没有id的数据,可以添加(唯一约束,又不是不为空约束)

insert into temp (name)values('李四');

添加一条id为1 的数据

insert into temp (id,name)values(1,'王五');

再添加一条id为1的数据,报错,因为已经有了id为1了,不可重复

insert into temp (id,name)values(1,'赵六');

第二种 : 创建表之后,添加unique约束

   create table temp1 (

    id int ,

    `name` varchar(20)

);

alter table temp1 add unique (id);

添加一条没有id的数据

insert into temp1 (name)values('张三');

再添加一条没有id的数据,可以添加(唯一约束,又不是不为空约束)

insert into temp1 (name)values('李四');

添加一条id为1 的数据

insert into temp1 (id,name)values(1,'王五');

再添加一条id为1的数据,报错,因为已经有了id为1了,不可重复

insert into temp1 (id,name)values(1,'赵六');

非空约束 not null与 默认值 default

设置not null 与 default有两种方式 : 

第一种 : 创建表时,添加约束

第二种 : 创建表之后,添加约束

下面是使用方式

第一种 : 创建表时,添加约束

create table temp2(

    id int not null,

    `name` varchar(30) default  'abc',

sex varchar(10) not null default '男'

);

测试语句 :

只添加id值,可以,因为name和sex都有默认值

insert into temp2 (id) values (1);

如果设置了值,默认值就不再设置

insert into temp2 (id,name,sex) values (2,'张三','女');

注意 : 没有添加id的值,而id又设置不能为空,并且也没有默认值,所以报错

insert into temp2 (name,sex) values ('李四','女');

第二种 : 创建表之后,添加约束

语法 : alter table 表名 modify 列名 数据类型 not null  default 默认值;

create table temp3(

    id int,

    `name` varchar(30) ,

sex varchar(10)

);

alter table temp3 modify id int not null ;

alter table temp3 modify name  varchar(30)   default  'abc';

alter table temp3 modify sex varchar(10) not null  default '男';

测试语句 :

只添加id值,可以,因为name和sex都有默认值

insert into temp3 (id) values (1)

如果设置了值,默认值就不再设置

insert into temp3 (id,name,sex) values (2,'张三','女');

没有添加id的值,而id又设置不能为空,并且也没有默认值,所以报错

insert into temp3 (name,sex) values ('李四','女');

Check扩展约束

CHECK:检查约束(MySql不支持),检查字段的值是否为指定的值

一般用于性别等,对列的值做一些限制,比如 性别列的值只能是男或者女

但是MySQL这里给舍弃了,不再支持,所以六大约束就成了五大约束

基础DQL

语法 :

select 列限定 from 表限定 where 行限定;

示例代码 :

create table teacher(

id int,

`name` varchar(30)

);

insert into teacher (id,name) values (1,'张老师');

insert into teacher (id,name) values (2,'王老师');

最简单粗暴的一个DQL :

select * from teacher;

会查询到teacher表中所有的数据

如果想查看所有行的name

select name from teacher;

如果想查看id为1的讲师姓名

select name from teacher where id = 1;

条件判断

and

且,和,的意思,一般用于 必须符合两个添加的判断,等同于java中的 &&

语法 :

select 列限定 from 表限定 where A表达式 and B表达式;

如 : 查询学生表中,name是张三且成绩大于90分

select * from student where name='张三' and score > 90;

只会查询出符合两个条件的学生

or

或的意思,一般用于 符合一个添加判断的情况下,等同于java中的 ||

语法 :

select 列限定 from 表限定 where A表达式 or B表达式;

如 : 查询学生表中,name是张三 或 成绩大于90分

select * from student where name='张三' or score > 90;

只要符合两个条件中的任何一个条件,就可以

注意 : 如果 一个语句中,同时出现了and和or的话,and优先级高

关系表达式

> , >= , <  , <= ,<>,=

> : 大于

< : 小于

>= : 大于等于

<= : 小于等于

= : 相等

<> : 不等于

注意 : = 和 <> 额外留意,和java中有所不同,java中判断相等用 == , 这里只用 = , java中判断不相等用 != , 这里使用 <>

如 : 查询学生表中,成绩大于90分的

select * from student where  score > 90;

如 : 查询学生中,成绩为空的学生

错误 判断为空不能使用 = null ,应该使用 is null

select * from student where score = null;

select * from student where  score is null;

如 : 查询学生中,成绩不为空的学生

错误 判断不为空 不能使用 <>null,应该使用 is not null

select * from student where  score  <> null;

select * from student where  score is not  null;

注意 : 判断是否为空,应该使用is null,而不是 = null , 同理,判断不为空应该使用 is not null ,而不是 <>null,并且and和or同时出现的话,and优先级比or要高

between  and

在...之间

语法 :

select 列限定 from 表限定 where 列名 between 值1 and 值1;

如 : 查询学生表中 成绩在98到100之间 (包含98和100)

select * from student where score >= 98 and score<=100;  

等价于

select * from student where score between 98 and 100;

In

在指定数据中

语法 :

select 列限定 from 表限定 where 列名 in(值1,值2....);

如 : 给出一个数据集合(1,3,10,20),获取学生id在这个数据集合中的学生信息

select * from student where id in (1,3,10,20);

模糊查询like

我们经常会用到搜索功能,比如百度,搜索功能实现,就是使用like模糊查询技术点

其中 % 匹配任意个数的任意字符

 _ 匹配单个任意字符

语法 :

select 列限定 from 表限定 where 列名 like  '值' ;

如 : 把name中,把姓张的查询出来

select * from student where  name like '张%';

如 : 把 name中,姓名有两个字的查询出来

select * from student where  name like '__';

如果想要查询 _ 或者 % 需要转义  \%   \_

Order by 排序

排序,望文知意,能够让我们查询的数据进行排序展示
语法 :

select 列限定 from 表限定 order by 列名 asc/desc;

Asc : 升序

Desc : 降序

如 : 查询所有学生信息,以成绩降序

select * from student order by score desc;

如 : 查询所有学生信息,按成绩降序,如果成绩相同,按照id升序

select * from  student order by score desc , id asc;

Limit

限制条数,通常和order by一起使用,因为我们使用排序之后,再去获取前几条数据,比较有价值,比如成绩前三名

语法 :

select 列限定 from 表限定 limit 条数;

select 列限定 from 表限定 limit 开始值(不包含) ,条数;

如 : 查询学生表,分数前三名的信息

select * from  student order by score desc limit 3;

如 : 查询学生表,分数第二名和第三名

select * from  student order by score desc limit 1,2;

单表查询(组函数)

常用组函数有 :

count(*) : 总条数

max(字段名) : 最大值

min(字段名) : 最小值

avg(字段名) : 平均值

sum(字段名) : 总和

语法 :

select  count(*),max(字段名),min(字段名)... from 表名 group by 字段名;

如 : 查看学生表共有多少学生

select  count(*)  from   student;

如 : 查看学生表中分数大于90分的有多少学生

select  count(*)  from   student where score > 90;

Group by

如 : 查询每个老师分别带了多少学生(显示老师id即可)

select teacher_id, count(*) as stu_count  from student group by teacher_id;

如 : 查询每个老师带的学生中的最高分数

select teacher_id, count(*) as stu_count,max(score) as stu_max_score from student group by teacher_id;

如 : 查询每个老师所带学生的总成绩与平均分

select teacher_id, sum(score) as sum,avg(score) as avg from student group by teacher_id;

Having

刚才我们使用group by 和 组函数,可以对数据进行分组查询,并且也可以查询到平均值等数据

但是有时候我们也需要做一些判断,比如求出平均值了,我只想要平均值 大于60分的平均分数,这时候用where就不行了

select teacher_id, avg(score) as avg from student  where avg > 60  group by teacher_id;

这个时候就需要使用having进行过滤

select teacher_id, avg(score) as avg from student group by teacher_id having avg > 60;

子查询

子查询又叫嵌套查询。它通常可以位于SELECT后面 FROM后面 WHERE后面,共三种使用场景。当我们查询一个表没有办法实现功能的时候,就需要使用子查询

 : select后面

语法 :

select 字段名,(查询语句) from 表名;

如  : 查询所有学生的信息并显示老师的名字

select *,(

         select name from teacher where id=teacher_id   

     ) as teacher_name from student ;

如 : 查询每个老师的学生的 最大分数,最小分数,平均分数,分数总和,学生人数,老师名字

select max(score),min(score),sum(score),avg(score),count(*),(

        select name from teacher where id=teacher_id

        ) as teacher_name from student group by teacher_id ;

 from后面

还是学生表student,我们要将成绩进行分级,并且显示汉字的分级与字母的分级。这里可以使用子查询。相当于给student“新增”了2个字段

如 : 使用子查询 对成绩划分等级, score<60 ,评级C 并且是差,score>=60 且 score<80 评级B并且是良,score>=80 评级是A并且是优

select *,

case rank

when 'A' then '优'

when 'B' then '良'

when 'C' then '差'

end rank_ch

from (

select *,

case

when score < 60 then 'C'

when score >=60 and score <80 then 'B'

when score >=80 then 'A'

end as rank

from student

) a;

注意 :

当位于FROM后面时,要注意

1.我们可以把子查询当成一张表

2.必须要有别名,因为子查询优先被执行,子查询的别名,可以让别的查询当做表或者列去操作

 where后面

如 : 在不知道teacher_id 和 老师名字的对应关系的情况下,想查询出张老师下面的所有学生信息

select * from student where teacher_id in (

select id from teacher where name='张老师'

Union与 union all

合并查询,合并查询的结果

Union 会去除重复项

Union all 不会去除重复项

如 : 查询出 teacher_id = 1 的所有学生信息

select * from student where teacher_id=1;

如 : 查询出 学生分数大于60的所有学生信息

select * from student where score > 60;

如 : 查询出 学生分数大于60 或 teacher_id = 1 的所有学生信息(去除重复)

// 用 or 实现

select * from student where teacher_id=1 or score > 60;

// 用 union实现

select * from student where teacher_id=1

     union

select * from student where score > 60;

如 : 查询出 学生分数大于60 或 teacher_id = 1 的所有学生信息(可重复)

select * from student where teacher_id=1

     union all

select * from student where score > 60;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值