`
coconut_zhang
  • 浏览: 543696 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

数据库面试(Oracle与Sql专题)

阅读更多
oracle Certification Program (OCP认证)的题目

  (1) A 表中有100条记录.

  Select * FROM A Where A.COLUMN1 = A.COLUMN1

  这个语句返回几条记录? (简单吧,似乎1秒钟就有答案了:)

  (2) Create SEQUENCE PEAK_NO

  Select PEAK_NO.NEXTVAL FROM DUAL --> 假设返回1

  10秒中后,再次做


  Select PEAK_NO.NEXTVAL FROM DUAL --> 返回多少?

  (3) SQL> connect sys as sysdba

  Connected.


  SQL> insert into dual values ( 'Y');

     1 row created.

  SQL> commit;

     Commit complete.

  SQL> select count(*) from dual;

     COUNT(*)

     ----------

     2

  SQL> delete from dual;

     commit;

     -->DUAL里还剩几条记录?

  JUST TRY IT
一些高难度的SQL面试题

  以下的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 <=1);
 
Select count(*) from usertable t1 where exists
  (select 'x' from usergrade t2 where t1.username=t2.username and rownum <=1);

以上语句的执行结果是:(  )  (  )
  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 <=100;

T3                                          begin
                                             delete from t where rownum <=100;  
                                             commit;
                                           end;
                                           /
                                             
T4         truncate table t;

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

A:  1000        B:   900     C:   800     D:   0
分享到:
评论

相关推荐

    数据库面试题SQL+ORACLE

    本知识点将以数据库面试题中常见的SQL和ORACLE相关问题为载体,详细介绍数据库的基础知识。 首先,数据库基础部分主要介绍了数据的抽象层次,包括物理抽象、概念抽象、视图级抽象,以及内模式、模式、外模式的概念...

    史上最全Oracle和SQL数据库面试题打包

    Oracle和SQL数据库是IT行业中极为重要的两个概念,广泛应用于企业数据管理和分析。Oracle是一种关系型数据库管理系统(RDBMS),由甲骨文公司开发,以其高效、稳定和强大的功能著称;而SQL(Structured Query ...

    【整理】数据库面试题索引sql优化+数据库SQL优化总结之百万级数据库优化

    本文将深入探讨数据库面试中的常见问题,特别是关于SQL优化和针对大规模数据库的优化策略。首先,我们来看看"数据库面试题索引sql优化.pdf"可能涵盖的内容。 1. **SQL基础与语法**:面试通常会涉及到SQL的基本概念...

    数据库面试题(SQL ORACLE)

    SQL(Structured Query Language)是用于操作关系型数据库的语言,包含了数据定义、数据操纵和数据控制三大功能。数据定义涉及创建、修改和删除表、索引等,如`CREATE TABLE`、`ALTER TABLE`、`DROP TABLE`等。数据...

    数据库面试题(SQL+ORACLE)

    ### 数据库面试题(SQL+ORACLE) #### 一、数据库基础知识 1. **数据抽象**: - **物理抽象**:指数据在物理层面上如何存储和管理。 - **概念抽象**:指数据在逻辑层面上的概念模型,通常与业务逻辑紧密相关。 - ...

    数据库面试题(SQL+ORACLE

    ### 数据库面试题(SQL+ORACLE) #### 一、数据库基础知识 1. **数据抽象**: - **物理抽象**:指数据在物理层面上如何存储和管理。 - **概念抽象**:从用户的角度来看待数据,关注的是数据的概念模型而非具体的...

    数据库面试题(SQL+ORACLE).

    ### 数据库面试题(SQL+ORACLE)知识点梳理 #### 一、数据抽象与数据库模式 - **数据抽象**:在数据库设计中,数据抽象是指通过不同的级别来组织和描述数据的过程,主要包括三个层面: - **物理抽象**:指的是如何...

    sql和oralce等数据库面试题

    ### SQL和Oracle数据库面试题知识点解析 #### 1. 数据库操作基础 - **DDL (Data Definition Language)**:用于定义数据库结构的语言。包括 `CREATE TABLE`、`ALTER TABLE` 和 `DROP TABLE` 命令,以及索引的创建和...

    Oracle数据库DBA面试题50道及答案.pdf

    在准备面试Oracle数据库管理员岗位时,掌握相关的技术知识和处理问题的能力是非常重要的。以下是针对给定的Oracle数据库DBA面试题的知识点详细解析: 1. **冷备份和热备份的区别及其优点**: - **热备份**:在...

    oracle数据库面试题目汇总.pdf

    本资源摘要信息将涵盖 Oracle 数据库面试题目汇总的关键知识点,涵盖字符串操作函数、事务概念、查询系统时间、触发器的作用、数字函数、关系数据库系统与文件数据库系统的区别、触发器和存储过程的概念等方面。...

    oracle数据库面试题目集锦

    在面试中,Oracle相关的知识通常涉及数据库管理、SQL语法、数据类型、函数、触发器、事务处理等方面。下面将对这些知识点进行详细的解释。 1. 字符串操作函数: - `ASCII()`:返回字符串第一个字符的ASCII码。 - ...

    常见Oracle数据库面试题目

    ### 常见Oracle数据库面试题目解析 #### 1. 列出至少有一个员工的所有部门 此题旨在考察考生如何筛选出至少有一名员工所在的部门。解决方案是通过使用`GROUP BY`结合`HAVING`子句来实现。具体步骤如下: - 使用`...

    数据库面试题(SQL+ORACLE)..zip

    在准备数据库相关的面试时,尤其是SQL和Oracle这两个关键领域...熟悉以上知识点将极大地提升你在数据库面试中的竞争力。记住,理论知识和实践经验同样重要,所以不仅要理解这些概念,还要尽可能地通过实践来加深理解。

    面试oracle必备的sql语句

    ### 面试Oracle必备的SQL语句知识点详解 #### 1. 查看表空间的名称及大小 在Oracle数据库管理中,了解每个表空间的大小对于资源管理和优化至关重要。以下SQL语句可以帮助我们获取各个表空间的名称及其总大小(以MB...

    Oracle数据库面试题及答案

    Oracle 数据库面试题及答案 Oracle 数据库是关系数据库管理系统的领导者,本文总结了常见的 Oracle 数据库面试题,旨在帮助尚在找工作的大蛱们。下面是详细的知识点解释: 1. 如何判断数据库的时区? 答案:SELECT...

    ORAcle sql数据库面试题

    各大公司数据库面试题,有关于oracle sql的,经典案例

    数据库面试题4 oracle笔试 oracle例题

    【数据库面试题4:Oracle笔试 Oracle例题】 在Oracle数据库的使用中,SQL语句的性能优化至关重要,尤其是在处理大规模数据时。优化SQL语句能够显著提升系统的响应速度,提高系统的可用性和效率。以下是一些关于SQL...

    数据库面试题(SQL+ORACLE)-DBA数据库管理员JAVA程序员架构师必看.pdf,这是一份不错的文件

    数据库面试题(SQL+ORACLE)-DBA数据库管理员JAVA程序员架构师必看.pdf,这是一份不错的文件

Global site tag (gtag.js) - Google Analytics