SQL面试题

单表查询面试题

准备数据

CREATE TABLE students (

studentNo int(10) primary key auto_increment,

name varchar(10),

sex varchar(1),

hometown varchar(20),

age int(4),

class varchar(10),

card varchar(20)

);

INSERT INTO students (name, sex, hometown, age, class, card)

VALUES ('王昭君', '女', '北京', '20', '1班', '340322199001247654'),

('诸葛亮', '男', '上海', '18', '2班', '340322199002242354'),

( '张飞', '男', '南京', '24', '3班', '340322199003247654'),

( '白起', '男', '安徽', '22', '4班', '3403221 99005247654'),

( '大乔', '女', '天津', '19', '3班', '340322199004247654'),

('孙尚香', '女', '河北', '18', '1班', '340322199006247654'),

( '百里玄策', '男', '山西', '20', '2班', '340322199007247654'),

( '小乔', '女', '河南', '15', '3班', NULL),

( '百里守约', '男', '湖南', '21', '1班', ''),

( '妲己', '女', '广东', '26', '2班', '340322199607247654'),

( '李白', '男', '北京', '30', '4班', '340322199005267754'),

( '孙膑', '男', '新疆', '26', '3班', '340322199000297655');

CREATE TABLE courses (

courseNo int(10) PRIMARY KEY AUTO_INCREMENT,

name varchar(10)

);

INSERT INTO courses

VALUES ('1', '数据库'),

('2', 'qtp'),

('3', 'linux'),

('4', '系统测试'),

('5', '单元测试'),

('6', '测试过程');

CREATE TABLE scores (

id int(10) PRIMARY KEY AUTO_INCREMENT,

courseNo int(10),

studentNo int(10),

score int(4)

);

INSERT INTO scores

VALUES ('1', '1', 1, '90'),

('2', '1', 2, '75'),

('3', '2', 2, '98'),

('4', '3', 1, '86'),题目

1、查询学生"百里守约"的基本信息

2、查询学生"百里守约"或”百里玄策”的基本信息

3、查询姓"张"学生的姓名,年龄,班级

4、查询姓名中含有"约"字的学生的基本信息

5、查询姓名长度为三个字,姓“孙”的学生的学号,姓名,年龄,班级,身份证号

6、查询姓"百"或者姓”孙”的学生的基本信息

7、查询姓"百"并且家乡是"山西"的学生信息

8、查询家乡是"北京"、”新疆”、”山东”或者"上海"的学生的信息

9、查询姓"孙",但是家乡不是"河北"的学生信息

10、查询家乡不是"北京"、"新疆"、"山东"、"上海"的学生的信息

11、查询全部学生信息,并按照“性别”排序

('5', '3', 3, '80'),

('6', '4', 4, '79'),

('7', '5', 5, '96'),

('8', '6', 6, '80');

select * from students where name='百里守约'

select * from students where name='百里守约' or name='百里玄策'

select name,age,class from students where name like '张%'

select * from students where name like '%约%'

select studentNo,name,age,class,card from students where name like '孙__'

select * from students where name like '百%' or name like '孙%'

select * from students where name like '百%' and hometown='山西'

select * from students where hometown in('北京','新疆','山东','上海')

select * from students where name like '孙%' and hometown!='河北'

select * from students where hometown not in('北京','新疆','山东','上海')12、查询现有学生都来自于哪些不同的省份

13、查询所有男生,并按年龄升序排序

14、统计共有多少个学生

15、统计年龄大于20岁的学生有多少个

16、统计男生的平均年龄

17、查询1班学生中的最大年龄是多少

18、统计2班男女生各有多少人

19、统计每个班级中每种性别的学生人数,并按照班级升序排序

多表查询面试题

准备数据

select * from students order by sex

select hometown from students group by hometown

select * from students where sex='男' order by age

select count(*) from students

select count(*) from students where age>20

select avg(age) from students where sex='男'

select max(age) from students where class='1班'

select sex,count(*) from students where class='2班' group by sex

select class,sex,count(*) from students group by class,sex order by class

create table departments (

deptid int(10) primary key,

deptname varchar(20) not null -- 部门名称

);

insert into departments values ('1001', '市场部');

insert into departments values ('1002', '测试部');

insert into departments values ('1003', '开发部');

create table employees (题目

1.列出总人数大于4的部门号和总人数

2.列出开发部和测试部的职工号,姓名

empid int(10) primary key,

empname varchar(20) not null, -- 姓名

sex varchar(4) default null, -- 性别

deptid int(20) default null, -- 部门编号

jobs varchar(20) default null, -- 岗位

politicalstatus varchar(20) default null, -- 政治面貌

leader int(10) default null

);

insert into employees values ('1', '王昭君', '女', '1003', '开发', '群众', '9');

insert into employees values ('2', '诸葛亮', '男', '1003', '开发经理', '群众',

null);

insert into employees values ('3', '张飞', '男', '1002', '测试', '团员', '4');

insert into employees values ('4', '白起', '男', '1002', '测试经理', '党员', null);

insert into employees values ('5', '大乔', '女', '1002', '测试', '党员', '4');

insert into employees values ('6', '孙尚香', '女', '1001', '市场', '党员', '12');

insert into employees values ('7', '百里玄策', '男', '1001', '市场', '团员', '12');

insert into employees values ('8', '小乔', '女', '1002', '测试', '群众', '4');

insert into employees values ('9', '百里守约', '男', '1003', '开发', '党员', '9');

insert into employees values ('10', '妲己', '女', '1003', '开发', '团员', '9');

insert into employees values ('11', '李白', '男', '1002', '测试', '团员', '4');

insert into employees values ('12', '孙膑', '男', '1001', '市场经理', '党员', null);

create table salary (

sid int(10) primary key,

empid int(10) not null,

salary int(10) not null -- 工资

);

insert into salary values ('1', '7', '2100');

insert into salary values ('2', '6', '2000');

insert into salary values ('3', '12', '5000');

insert into salary values ('4', '9', '1999');

insert into salary values ('5', '10', '1900');

insert into salary values ('6', '1', '3000');

insert into salary values ('7', '2', '5500');

insert into salary values ('8', '5', '2000');

insert into salary values ('9', '3', '1500');

insert into salary values ('10', '8', '4000');

insert into salary values ('11', '11', '2600');

insert into salary values ('12', '4', '5300');

select deptid, count(*) from employees e group by deptid having count(*)>4

select e.empid,d.empname

from employees e inner join departments d on e.deptid = d.deptid

where d.deptname in ('开发部','测试部')3.求出各部门党员的人数,要求显示部门名称

select d.deptname,count(*)

from employees e inner join departments d on e.deptid=d.deptid

where e.politicalstatus ="党员" group by e.deptid

4.列出市场部的所有女职工的姓名和政治面貌

select e.empname,e.politicalstatus

from employees e inner join departments d on e.deptid = d.deptid

where e.sex= '女' and d.deptname = '市场部'

5.显示所有职工的姓名,部门名和工资数

select e.empname,d.deptname,s.salary

from employees e

inner join departments d on e .deptid = d.deptid

inner join salary s on e.empid = s.empid

6.显示各部门名和该部门的职工平均工资

select d.deptname, avg(s.salary)

from departments d

inner join employees e on d.deptid = e.deptid

inner join salary s on e.empid = s.empid

group by d.deptname

7.显示工资最高的前3名职工的职工号和姓名

select e.empid, e.empname,s.salary

from salary s inner join employees e on s.empid = e.empid

order by s.salary desc

limit 3

8.列出工资在1000-2000之间的所有职工姓名

select e.empname,s.salary

from salary s

inner join employees e on s.empid = e.empid

where s.salary between 1000 and 2000

9.列出工资比王昭君高的员工

select *

from employees e

inner join salary s on e.empid=s.empid

where s.salary > (

select s.salary from employees e inner join salary s on e.empid=s.empid where

e.empna me='王昭君'

)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容