MySQL基础总结

首先,今天学习遇到一点小问题

mysql中出现 Unknown column ‘xxx‘ in ‘having clause‘

这是因为在使用group by分组时,后面如果需要再加一个having进行判断,则所判断的字段需要在select后面出现

例如

select c.studentNo, c.name, count(coursename)
from courses a, scores b, students c
where a.courseNo = b.courseNo
and b.studentNo = c.studentNo
GROUP BY c.studentNo
having count(coursename) = 5

 count(coursename)在select和having后面都得出现,否则就会报下面这个错

MySQL基础总结

 另外总结了一下SQL的易错点

首先就是一定要拼对

  • 当group by 与聚合函数配合使用时,功能为分组后计算

select count(id)

from employee 

group by id

  • 当group by 与having配合使用时,功能为分组后过滤

select count(id)

from employee 

group by id

having count(id)>2

  • 当group by 与聚合函数,同时非聚合字段同时使用时,非聚合字段的取值是第一个匹配到的字段内容,即id小的条目对应的字段内容

select count(id),name

from employee 

group by id

having count(id)>2

  • inner join 是前一个表和后一个表逐项去比较
  • SELECT u.name as 'his name' from user as u

    而不是

     SELECT u.name as his name from user as u

    下面的会报错,其实就是字符串类型,但是常常忽略 ' ',导致结果报错

下面是今天基础语句的一些操作 

简单DDL:

DDL : 数据库定义语言

涉及的关键字 : create drop alter

alter

更改表名

alter table 表名 rename 新表名;

更改字段名

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

添加字段

alter table 表名add 列名类型;

删除字段

alter table 表名 drop 列名;

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

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

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

查看建表语句

show create table 表名;

实体完整性(主键)

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

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

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

主键自增:

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

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

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

关联完整性(外键)

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

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

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

唯一约束unique:

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

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

alter table temp1 add unique (id);

非空约束 not null与 默认值 default

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

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

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

基础DQL

DQL : Data Query Language,数据查询语言,主要用于查询表。

它通常用来从一张表或者多张表(视图或者子查询等)中按指定的条件筛选出某此记录。涉及到的命令有select。

语法 :

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

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中判断不相等用 != , 这里使用 <>

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  '值' ;

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;

单表查询(组函数)
Group by Having

子查询

场景一 : select后面

注意 :

当位于SELECT后面时,要注意

1.一定要在两个表之间找好对应关系(teacher.id必须是主键或者必须保证teacher.id在teacher表中是唯一的)

2.子查询中只能有一个字段(子查询的结果必须是一行一列)

使用子查询的时候,建议大家养成使用别名的好习惯,这样可以让我们的查询语句更加清晰。别名可以用来命令新字段,也可以用来命名新表.

场景二 : from后面

注意 :

当位于FROM后面时,要注意

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

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

场景三 : where后面

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

select * from student where teacher_id in (

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

);

注意 :

当位于WHERE后面时,要注意

多条数据要用in而不要用=,如果确定子查询的结果为一行一列的话,就可以用 = 等于
如果返回结果为多行一列的话 要用 in , 一列是必须的,必须是一列
3.子查询中的SELECT后面只能有一个字段(多个字段的话会报错)
 

上一篇:Navicat 连接MySQL 8.0.11 出现2059错误


下一篇:Flask Web Development —— Web表单(上)