一些高难度的SQL面试题


Posted in 面试题 onNovember 29, 2016
以下的null代表真的null,写在这里只是为了让大家看清楚

根据如下表的查询结果,那么以下语句的结果是(知识点:not in/not exists+null)
SQL> select * from usertable;
USERID USERNAME
———– —————-
1 user1
2 null
3 user3
4 null
5 user5
6 user6

SQL> select * from usergrade;
USERID USERNAME GRADE
———- —————- ———-
1 user1 90
2 null 80
7 user7 80
8 user8 90
执行语句:

select count(*) from usergrade where username not in (select username from usertable);

select count(*) from usergrade g where not exists
(select null from usertable t where t.userid=g.userid and t.username=g.username);

结果为:语句1( 0 ) 语句2 ( 3 )

A: 0 B:1 C:2 D:3 E:NULL

2

在以下的表的显示结果中,以下语句的执行结果是(知识点:in/exists+rownum)
SQL> select * from usertable;
USERID USERNAME
———– —————-
1 user1
2 user2
3 user3
4 user4
5 user5

SQL> select * from usergrade;
USERNAME GRADE
—————- ———-
user9 90
user8 80
user7 80
user2 90
user1 100
user1 80

执行语句
Select count(*) from usertable t1 where username in
(select username from usergrade t2 where rownum
Select count(*) from usertable t1 where exists
(select ‘x’ from usergrade t2 where t1.username=t2.username and rownum
以上语句的执行结果是:( ) ( )
A: 0 B: 1 C: 2 D: 3

根据以下的在不同会话与时间点的操作,判断结果是多少,其中时间T1 原始表记录为;
select * from emp;
EMPNO DEPTNO SALARY
—– —— ——
100 1 55
101 1 50
select * from dept;
DEPTNO SUM_OF_SALARY
—— ————-
1 105
2

可以看到,现在因为还没有部门2的员工,所以总薪水为null,现在,
有两个不同的用户(会话)在不同的时间点(按照特定的时间顺序)执行了一系列的操作,那么在其中或最后的结果为:

time session 1 session2
———– ——————————- ———————————–
T1 insert into emp
values(102,2,60)

T2 update emp set deptno =2
where empno=100

T3 update dept set sum_of_salary =
(select sum(salary) from emp
where emp.deptno=dept.deptno)
where dept.deptno in(1,2);

T4 update dept set sum_of_salary =
(select sum(salary) from emp
where emp.deptno=dept.deptno)
where dept.deptno in(1,2);

T5 commit;

T6 select sum(salary) from emp group by deptno;
问题一:这里会话2的查询结果为:
T7 commit;
=======到这里为此,所有事务都已完成,所以以下查询与会话已没有关系========

T8 select sum(salary) from emp group by deptno;
问题二:这里查询结果为

T9 select * from dept;
问题三:这里查询的结果为

问题一的结果( ) 问题二的结果是( ) 问题三的结果是( )

A: B:
—————- —————-
1 50 1 50
2 60 2 55

C: D:
—————- —————-
1 50 1 115
2 115 2 50

E: F:
—————- —————-
1 105 1 110
2 60 2 55

有表一的查询结果如下,该表为学生成绩表(知识点:关联更新)
select id,grade from student_grade
ID GRADE
——– ———–
1 50
2 40
3 70
4 80
5 30
6 90

表二为补考成绩表
select id,grade from student_makeup
ID GRADE
——– ———–
1 60
2 80
5 60

现在有一个dba通过如下语句把补考成绩更新到成绩表中,并提交:
update student_grade s set s.grade =
(select t.grade from student_makeup t
where s.id=t.id);
commit;
请问之后查询:
select GRADE from student_grade where id = 3;结果为:

A: 0 B: 70 C: null D: 以上都不对

根据以下的在不同会话与时间点的操作,判断结果是多少,
其中时间T1
session1 session2
————————————– —————————————-
T1 select count(*) from t;
–显示结果(1000)条

T2 delete from t where rownum
T3 begin
delete from t where rownum commit;
end;
/

T4 truncate table t;

T5 select count(*) from t;
–这里显示的结果是多少

A: 1000 B: 900 C: 800 D: 0

Tags in this post...

面试题 相关文章推荐
PHP笔试题
Feb 22 面试题
解释一下抽象方法和抽象类
Aug 27 面试题
简单说说tomcat的配置
May 28 面试题
C语言面试题
Oct 30 面试题
一套C++笔试题面试题
Jun 06 面试题
ddl,dml和dcl的含义
May 08 面试题
名词解释型面试题(主要是网络)
Dec 27 面试题
C#中有没有运算符重载?能否使用指针?
May 05 面试题
Linux常见面试题
Mar 18 面试题
几个常见的软件测试问题
Sep 07 面试题
广州某公司软件工程师面试题
Dec 22 面试题
初始化了一个没有run()方法的线程类,是否会出错?
Mar 27 面试题
在SQL Server中创建数据库主要有那种方式
Sep 10 #面试题
介绍一下SQL Server的全文索引
Aug 15 #面试题
什么是表空间(tablespace)和系统表空间(System tablespace)
Feb 25 #面试题
数据库的约束含义
Sep 09 #面试题
ddl,dml和dcl的含义
May 08 #面试题
索引覆盖(Index Covering)查询含义
Feb 18 #面试题
为什么group by 和order by会使查询变慢
May 16 #面试题
You might like
239军机修复记
2021/03/02 无线电
php后台程序与Javascript的两种交互方式
2009/10/25 PHP
基于PHP字符串的比较函数strcmp()与strcasecmp()的使用详解
2013/05/15 PHP
PHP通过插入mysql数据来实现多机互锁实例
2014/11/05 PHP
php数组生成html下拉列表的方法
2015/07/20 PHP
Laravel日志用法详解
2016/10/09 PHP
php 从指定数字中获取随机组合的简单方法(推荐)
2017/04/05 PHP
cnblogs 代码高亮显示后的代码复制问题解决实现代码
2011/12/14 Javascript
使用纯javascript实现经典扫雷游戏
2015/04/23 Javascript
jQuery实现的淡入淡出二级菜单效果代码
2015/09/15 Javascript
js获取url传值的方法
2015/12/18 Javascript
jQuery动画_动力节点节点Java学院整理
2017/07/04 jQuery
网页中的图片查看器viewjs使用方法
2017/07/11 Javascript
AngularJS中重新加载当前路由页面的方法
2018/03/09 Javascript
关于TypeScript模块导入的那些事
2018/06/12 Javascript
在小程序中集成redux/immutable/thunk第三方库的方法
2018/08/12 Javascript
Vuejs+vue-router打包+Nginx配置的实例
2018/09/20 Javascript
jquery实现的分页显示功能示例
2019/08/23 jQuery
vue表单验证之禁止input输入框输入空格
2020/12/03 Vue.js
Webpack3+React16代码分割的实现
2021/03/03 Javascript
Python使用Socket(Https)Post登录百度的实现代码
2012/05/18 Python
分享Python开发中要注意的十个小贴士
2016/08/30 Python
使用Python脚本实现批量网站存活检测遇到问题及解决方法
2016/10/11 Python
浅谈Python中的私有变量
2018/02/28 Python
浅谈Pycharm调用同级目录下的py脚本bug
2018/12/03 Python
python3+pyqt5+itchat微信定时发送消息的方法
2019/02/20 Python
python 串口读取+存储+输出处理实例
2019/12/26 Python
详解python datetime模块
2020/08/17 Python
美国领先的汽车轮胎和轮毂供应商:TireBuyer
2016/07/21 全球购物
什么是符号链接,什么是硬链接?符号链接与硬链接的区别是什么?
2013/05/03 面试题
How to spawning asynchronous work in J2EE
2016/08/29 面试题
大学军训通讯稿
2014/01/13 职场文书
居安思危观后感
2015/06/11 职场文书
Python+uiautomator2实现自动刷抖音视频功能
2021/04/29 Python
关于React Native使用axios进行网络请求的方法
2021/08/02 Javascript
maven 解包依赖项中的文件的解决方法
2022/07/15 Java/Android