首先,今天学习遇到一点小问题
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后面都得出现,否则就会报下面这个错
另外总结了一下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后面只能有一个字段(多个字段的话会报错)