1 、SQL COUNT(*) 函数用法总结
1 定义和用法
COUNT(*) 函数返回在给定的选择中被选的行数。
2 语法
SELECT COUNT(*) FROM table
3 例子
如下,有一个表格t_score
id | name | age | score |
1001 | Jack | 20 | 99 |
1002 | Rose | 21 | 89 |
1003 | Joy | 19 | 89 |
1004 | Lucy | 17 | 86 |
(1)返回表格的行数
SELECT count(*) FROM t_score
结果为:4
(2)返回大于等于20岁的人数
SELECT count(*) FROM t_score WHERE age >= 20
结果为:2
count(*) |
2 |
(3)返回所有字段score取值重复的记录,且重复次数大于1,结果按count大小逆序排列
SELECT score, count(*) AS count
FROM t_score
GROUP BY score HAVING count > 1
ORDER BY count DESC LIMIT 20
结果为:2
score | count |
89 | 2 |
SQL Count(*)函数,GROUP_By,Having的联合使用
2、SQL中WHERE和HAVING的区别
1 用的地方不同
where | 可以用于select、update、delete和insert into values(select * from table where ..)语句中 |
having | 只能用于select语句中 |
2 执行顺序不同
where | 使用where约束来自数据库的数据,where是在结果集返回之前起作用的,where中不能使用聚合函数 |
having | 在查询返回结果集以后对查询结果进行过滤操作,在Having中可以使聚合函数 |
where子句、聚合语句、having子句 | 执行优先级为where > group by > 聚合语句(sum、count、avg、max、min) > having子句 |
3 having用法
(1)用having就一定要和group by连用
(2)用group by不一有having (它只是一个筛选条件用的)
3 、SQL JOIN 多表查询总结
1 SQL JOIN 查询的各种用法汇总
2【 INNER JOIN】内连接
2.1 内连接通常有两种情况
(1)等值连接:查询两个表中连接字段相等的记录;
(2)自身连接:就是和自己进行连接查询,给一张表取两个不同的别名,然后附上连接条件。
2.2 语法
SELECT <auswahl> FROM tabelleA A INNER JOIN tabelleB B ON A.key = B.key
2.3 例子
表1 学生成绩表t_score
id | name | classId | score |
1001 | Jack | 201 | 99 |
1002 | Rose | 202 | 89 |
1003 | Joy | 201 | 89 |
1004 | Lucy | 301 | 86 |
表2 专业班级表t_class
id | className | grade |
201 | 七一班 | 1 |
202 | 七二班 | 1 |
301 | 八一班 | 2 |
(1)等值连接
//写法1:使用INNER JOIN(INNER可省去,直接写JOIN)
SELECT s.id AS studentId,s.name AS studentName,s.score,c.className
FROM t_score s JOIN t_class c
ON s.classId = c.id
//写法2:使用WHERE,已经逐渐被淘汰,推荐使用写法1
SELECT s.id AS studentId,s.name AS studentName,s.score,c.className
FROM t_score s,t_class c
WHERE s.classId = c.id
结果为:
studentId | studentName | score | className |
1001 | Jack | 99 | 七一班 |
1002 | Rose | 89 | 七二班 |
1003 | Joy | 89 | 七一班 |
1004 | Lucy | 86 | 八一班 |
(2)自身连接
//在成绩表中找到与 Jack 班级相同的学生信息
SELECT b.id,B.name,B.classId,B.score
FROM t_score A JOIN t_score B
ON A.classId = B.classId AND A.name = 'Jake'
结果为:
id | name | classId | score |
1001 | Jack | 201 | 99 |
1003 | Joy | 201 | 89 |