数据库SQL实战

本文介绍了一种使用SQL语句解决特定数据统计需求的方法。通过实际案例演示如何从数据库表中筛选并统计相同职位出现两次及以上的记录。文章首先展示了基本的SQL查询语句,包括COUNT函数和GROUP BY语句的结合使用,以及HAVING子句的应用;接着进一步讨论了在考虑去除重复员工编号的情况下,如何调整SQL语句实现更精准的数据统计。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

从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);

输入描述:

输出描述:

titlet
Assistant Engineer2
Engineer4
省略省略
Staff3

此题应注意以下三点:
 
 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





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值