题目描述
从titles表获取按照title进行分组,每组个数大于等于2,给出title以及对应的数目t。
CREATE TABLE IF NOT EXISTS "titles" (
`emp_no` int(11) NOT NULL,
`title` varchar(50) NOT NULL,
`from_date` date NOT NULL,
`to_date` date DEFAULT NULL);
CREATE TABLE IF NOT EXISTS "titles" (
`emp_no` int(11) NOT NULL,
`title` varchar(50) NOT NULL,
`from_date` date NOT NULL,
`to_date` date DEFAULT NULL);
输入描述:
无
输出描述:
title | t |
---|---|
Assistant Engineer | 2 |
Engineer | 4 |
省略 | 省略 |
Staff | 3 |
此题应注意以下三点:
1、用count()函数和group by语句可以统计同一title值的记录条数
2、根据题意,输出每个title的个数为t,故用AS语句将count(title)的值转换为t
3、由于where后不可跟count()函数,故用having语句来限定t>=2的条件
select title,count(title) t
from titles
group by title
having t >= 2
难度升级版:
从titles表获取按照title进行分组,每组个数大于等于2,给出title以及对应的数目t。注意对于重复的emp_no进行忽略。
思路:在上一题的基础上利用distinct对emp_no进行去重处理就行
select title,count(distinct emp_no) t
from titles
group by title
having t >= 2