qidao123.com技术社区-IT企服评测·应用市场

标题: 【金三银四】分享数据库笔试题及答案~~ [打印本页]

作者: tsx81428    时间: 2025-5-1 13:10
标题: 【金三银四】分享数据库笔试题及答案~~
你是否在口试中遇到过关于数据库的笔试题?如何高效地准备这些题目,提升自己的竞争力?本文将为你整理一些经典的数据库笔试题及其答案,助你备战口试。
金三银四立刻来了,测试年限较短难免会碰到笔试题,最近就收到一些求职小伙伴反馈过来的数据库笔试题,说不太会做。特意做了下摘录及答案整理,给大家做个分享。假如不想笔试受挫的宝子,一定要牢牢码住!并多多练习!
在求职季节,尤其是金三银四期间,许多测试人员面临数据库相关的笔试题目。把握常见的数据库笔试题及其解答,对于提升口试通过率至关紧张。
在现实口试中,数据库相关的笔试题目经常考察候选人的SQL本领和逻辑思维。通过对经典题目的练习,能够帮助我们更好地理解数据库的应用场景和办理方案。





一、已建立二张学生基本信息表,表的结构如下:


est表



test1表



1)用SQL语句找出是盘算机系并籍贯是北京的学生的全部记录
2)用SQL语句把盘算机系的学生的department改为信息学院
3)用SQL毗连查询找出结果大于等于75分的学生的no,name, grade,course字段的记录

参考答案:
1)
  1. select * from test where department='计算机系' and place='北京';
复制代码
2)
  1. UPDATE test SET department='信息学院' WHERE department='计算机系';
复制代码
3)
  1. select distinct test.no,test.name,test1.grade,test1.course from test,test1 where test.no=test1.no and test1.grade>=75;
复制代码



二、请按照如下题目要求编写 SQL


部门表 departments(dept_id, dept_name)
员工表 employees(emp_id,emp_name, sex, dept_id, jobs)
薪水表 salary (salary_id, emp_id, money)
问题1、 列出总人数大于 4 的部门编号和该部门人数
问题2、 列出开发部和测试部的职工号,姓名
问题3、 显示工资最高的前 3 名职工的职工号和姓名
问题4、 列出工资在 1000-2000 之间的全部职工姓名

参考答案:
1、
  1. select dept_id, count() as '部门人数' from employees e group by dept_id having count()>4;
复制代码
2、
  1. select e.emp_id,e.emp_name from employees e inner join departments d on e.dept_id = d.dept_id where d.dept_name in ('开发部','测试部');
复制代码
3、
  1. select e.emp_id, e.emp_name,s.money from salary s inner join employees e on s.emp_id = e.emp_id order by s.money desc limit 3;
复制代码
4、
  1. select e.emp_name,s.money from salary s inner join employees e on s.emp_id = e.emp_id where s.money between 1000 and 2000;
复制代码


 
三、根据下面Student、StudentScore表编写对应的数据库语句




1、查询均匀结果大于60的学生
2、用多表语句查询ID为1的学生的各科结果

参考答案:
1、
  1. select Student.* from Student, StudentScore where Student.ID = StudentScore.ID group by StudentScore.ID having avg(StudentScore.Score) > 60;
复制代码

2、
  1. select Student.ID, Student.name, StudentScore.C#, StudentScore.Score from
  2. Student,StudentScore where Student.ID = StudentScore.ID and Student.ID = 1;
复制代码


四、表OrderItems如下,按要求完成sql编写







参考答案:
  1. SELECT prod_id, quantity FROM OrderItems WHERE quantity = 100 or prod_id LIKE 'BNBG%' ORDER BY prod_id ASC;
复制代码


 
五、SQL基础:student(学生表)、class(班级表)










参考答案:
1、
  1. select class.name as c_Name,student.name,sex,score from student left join class on
  2. student.c_id = class.id where score = (select max(score) from student);
复制代码
2、
  1. SELECT c.NAME AS C_Name,COUNT(s.Id) AS Rs,AVG(s.Score) AS Score FROM student s JOIN class c
  2. ON s.c_Id=c.Id WHERE c.NAME IN ('一班','二班') GROUP BY c.NAME ORDER BY Score DESC;
复制代码


 
六、下图表a的信息,写sql得出图2的信息




从效果可以看出来题目是: 分别查出每年每月的amount值;
  1. SELECT year,
  2. SUM(IF(month='1', amount, 0)) as 'm1',
  3. SUM(IF(month='2', amount, 0)) as 'm2',
  4. SUM(IF(month='3', amount, 0)) as 'm3',
  5. SUM(IF(month='4', amount, 0)) as 'm4'
  6. FROM a
  7. GROUP BY year;
复制代码

七、企业表、用户表、专属司机表


企业表 t_orgnization: 企业id:org_id、企业名称:org_name,注册时间:created_time
用户表 t_user: 用户id:user_id,登录账号:login_name,暗码:pwd,真实姓名:real_name,所属企业id:org_id,注册时间:created_time
专属司机表 t_my_driver: 手机号:mobile_no,司机姓名:name,车牌号:car_percel_no,归属用户id:user_id
表之间的关系: 一个企业下可以注册多个用户,每个用户可以为自己注册多个专属司机
问题1: 查询所属企业id=86639,有真实姓名的用户信息,列出:登录账号,真实姓名,所属企业名称。
问题2: 查询拥有自己专属司机的用户所对应的企业信息,列出企业id,企业名称,注意去重。

参考答案:
1、
  1. SELECT t_user.login_name,t_user.real_name,t_orgnization.org_name FROM t_user LEFT JOIN t_orgnization ON t_orgnization.org_id=t_user.org_id WHERE t_user.org_id=86639 AND t_user.real_name IS NOT NULL;
复制代码

2、
  1. SELECT DISTINCT t_orgnization.org_id,t_orgnization.org_Name
  2. FROM t_orgnization
  3. LEFT JOIN t_user on t_user.org_id = t_orgnization.org_id
  4. LEFT JOIN t_my_driver on t_my_driver.user_id = t_user.user_id
  5. WHERE t_my_driver.user_id is not null;
复制代码



八、以下为学生表、课程表、结果表、西席表


Student(Sid,Sname,Sage,Ssex)学生表
Sid:学号
Sname:学生姓名
Sage:学生年事
Ssex:学生性别
Course(Cid,Cname,Tid)课程表
Cid:课程编号
Cname:课程名称
Tid:西席编号
Score(Sid,Cid,score)结果表
Sid:学号
Cid:课程编号
score:结果
Teacher(Tid,Tname)西席表
Tid:西席编号:
Tname:西席名字
试题1: 查询均匀结果大于60分的同学的学号宁静均结果,结果保留两位小数
试题2: 查询姓‘章’的老师的个数
试题3: 查询全部同学的学号、姓名、选课数、总结果
试题4: 查询没有学过“柠檬”老师课的同学的学号、姓名
试题5: 查询“C001”课程比“C002”课程结果高的全部学生的学号、姓名
试题6: 查询学过“C001”并且也学过编号“C002”课程的同学的学号、姓名
试题7: 查询全部课程结果小于60的同学的学号、姓名
试题8: 查询没有学全全部课的同学的学号、姓名
试题9: 查询学过“柠檬”老师所教的全部课的同学的学号、姓名
参考答案:
1、
  1. select Sid,ROUND(AVG(score), 2) from Score group by Sid having avg(score)>60;
复制代码
2、
  1. select count(Tname) from Teacher where Tname like '章%';
复制代码
3、
  1. select Student.Sid,Student.Sname,count(Score.Cid),sum(Score.score) from Student left join Score on Student.Sid=Score.Sid group by Student.Sname,Student.Sid;
复制代码
4、
  1. select Sid,Sname from Student where Sid not in (Select Score.Sid from Teacher,Score,Course where Course.Cid = Score.Cid and Course.Tid = Teacher.Tid and Teacher.Tname = '杨幂');
复制代码
5、
  1. Select a.Sid,a.Sname from Student a
  2. inner join Score b on a.Sid = b.Sid
  3. inner join Score c on a.Sid = c.Sid
  4. where (b.Cid = 'C001'and c.Cid ='C002') and b.score > c.score;
复制代码
6、
  1. select a.Sid,a.Sname from Student a inner join Score b on a.Sid=b.Sid inner join Score c on a.Sid=c.Sid where (b.Cid='c001' and c.Cid='c002');
复制代码
7、
  1. select Student.Sid,Student.Sname from Student,Score where Student.Sid = Score.Sid group by Score.Sid having max(Score.score)<60;
复制代码
8、
  1. SELECT S.Sid ,S.Sname FROM Student S LEFT JOIN Score Sc ON S.Sid=Sc.Sid GROUP BY S.Sid,S.Sname HAVING COUNT(DISTINCT Sc.Cid)< ( SELECT COUNT(*) FROM Course);
复制代码
9、
  1. SELECT Sid, Sname FROM Student WHERE Sid IN (
  2. SELECT Score.Sid
  3. FROM Score
  4. JOIN Course ON Course.Cid = Score.Cid
  5. JOIN Teacher ON Course.Tid = Teacher.Tid
  6. WHERE Teacher.Tname = '杨幂'
  7. GROUP BY Score.Sid
  8. HAVING COUNT(DISTINCT Course.Cid) = (
  9. SELECT COUNT(*)
  10. FROM Course join Teacher
  11. On Course.Tid = Teacher.Tid where Teacher.Tname = '杨幂'
  12. )
  13. );
复制代码


随着互联网行业的快速发展,数据库技能在软件测试中的紧张性日益凸显。把握扎实的数据库知识,已成为测试人员必备的技能之一。
通过对经典数据库笔试题的学习和练习,我们可以更好地把握数据库的核心概念和应用本领。持续的学习和实践,将为我们的职业发展奠基坚实的基础。



免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 qidao123.com技术社区-IT企服评测·应用市场 (https://dis.qidao123.com/) Powered by Discuz! X3.4