精华内容
下载资源
问答
  • 通过面试积累 。 。
  • oracle面试题

    2018-11-08 17:27:07
    oracle笔试!
  • oracle面试题

    2018-10-06 10:14:13
    收集很多文档最后去掉重复去掉比较啰嗦的解题留下来的多个文档。
  • Oracle面试题精选

    2019-04-19 00:29:14
    Oracle面试题精选,经典对单表和多表的增删改查,以及复杂查询.涉及方方面面的知识点..........
  • 经典的oracle面试题及答案,单表查询,多表关联查询,子查询,常用内置函数使用,多且全.
  • ORACLE 面试题PDF

    2019-07-29 01:06:14
    NULL 博文链接:https://mayuqi827.iteye.com/blog/804440
  • ORACLE面试题

    2019-03-18 17:36:10
    oracle面试问题 oracle面试题汇总 之一 一:SQL tuning 类 1:列举几种表连接方式 2:不借助第三方工具,怎样查看sql的执行计划 3:如何使用CBO,CBO与RULE的区别 4:如何定位重要(消耗资源多)的SQL 5:Oracle中如何跟踪...

    oracle面试问题 oracle面试题汇总 之一
    一:SQL tuning 类
    1:列举几种表连接方式
    2:不借助第三方工具,怎样查看sql的执行计划
    3:如何使用CBO,CBO与RULE的区别
    4:如何定位重要(消耗资源多)的SQL
    5:Oracle中如何跟踪某个session的SQL
    6:SQL调整最关注的是什么
    7:说说你对索引的认识(索引的结构、对dml影响、对查询影响、为什么提高查询性能)
    8:使用索引查询一定能提高查询的性能吗?为什么
    9:绑定变量是什么?绑定变量有什么优缺点?
    10:Oracle中如何稳定(固定)执行计划
    11:和排序相关的内存在8i和9i分别怎样调整,临时表空间的作用是什么
    12:存在表T(a,b,c,d),要根据字段c排序后取第21—30条记录显示,请给出sql

    二:Oracle数据库基本概念类

    1:pctused and pctfree 表示什么含义有什么作用
    2:简单描述table / segment / extent / block之间的关系
    3:描述tablespace和datafile之间的关系
    4:本地管理表空间和字典管理表空间的特点,ASSM有什么特点
    5:Oracle回滚段的作用是什么
    6:Oracle日志的作用是什么
    7:SGA主要有那些部分,主要作用是什么
    8:Oracle系统进程主要有哪些,作用是什么

    三:备份恢复类

    1:备份如何分类

    2:归档是什么含义

    3:如果一个表在2004-08-04 10:30:00 被drop,在有完善的归档和备份的情况下,如何恢复

    4:rman是什么,有何特点

    5:standby的特点

    6:对于一个要求恢复时间比较短的系统(数据库50G,每天归档5G),你如何设计备份策略

    四:系统管理类

    1:对于一个存在系统性能的系统,说出你的诊断处理思路
    2:列举几种诊断IO、CPU、性能状况的方法
    3:对statspack有何认识
    4:如果系统现在需要在一个很大的表上创建一个索引,你会考虑那些因素,如何做以尽量减小对应用的影响
    5:对raid10 和raid5有何认识

    综合随意类

    1:你最擅长的是oracle哪部分?
    2:喜欢oracle吗?喜欢上论坛吗?或者偏好oracle的哪一部分?
    3:随意说说你觉得oracle最有意思的部分或者最困难的部分
    4:为何要选择做DBA呢?

    Oracle笔试题-- oracle面试问题-技术篇
    oracle DBA 面试题及答案
    在关注Oracle技术问题的同时,请务必阅读有关面试中有关个人的问题和解答,让面试考官了解你对ORACLE概念的熟悉程度。

    1.解释Oracle冷备份和热备份的不同点以及各自的优点 

      解答:热备份针对归档模式的数据库,在数据库仍旧处于工作状态时进行备份。而冷备份指在数据库关闭后,进行备份,适用于所有模式的数据库。热备份的优点在于当备份时,数据库仍旧可以被使用并且可以将数据库恢复到任意一个时间点。冷备份的优点在于它的备份和恢复操作相当简单,并且由于冷备份的数据库可以工作在非归档模式下,数据库性能会比归档模式稍好。(因为不必将archive log写入硬盘)

      2.你必须利用备份恢复Oracle数据库,但是你没有控制文件,该如何解决问题呢?

      解答:重建控制文件,用带backup control file 子句的recover 命令恢复Oracle数据库。

      3.如何转换init.ora到spfile?

      解答:使用create spfile from pfile 命令.

      4.解释data block , extent 和 segment的区别(这里建议用英文术语) 

      解答:data block是数据库中最小的逻辑存储单元。当数据库的对象需要更多的物理存储空间时,连续的data block就组成了extent . 一个数据库对象拥有的所有extents被称为该对象的segment.

      5.给出两个检查Oracle表结构的方法 

      解答:1.DESCRIBE命令

         2.DBMS_METADATA.GET_DDL 包

      6.怎样查看Oracle数据库引擎的报错

      解答:alert log.

    展开全文
  • Oracle面试题

    万次阅读 多人点赞 2018-11-01 12:07:50
    1. 如何使用Oracle的游标?  1). oracle中的游标分为显示游标和隐式游标  2). 显示游标是用cursor...is命令定义的游标,它可以对查询语句(select)返回的多条记录进行处理;隐式游标是在执行插入 (insert)、删除...

     

    1. 如何使用Oracle的游标? 

    1).  oracle中的游标分为显示游标和隐式游标 

    2).  显示游标是用cursor...is命令定义的游标,它可以对查询语句(select)返回的多条记录进行处理;隐式游标是在执行插入 (insert)、删除(delete)、修改(update)和返回单条记录的查询(select)语句时由PL/SQL自动定义的。 

    3). 显式游标的操作:打开游标、操作游标、关闭游标;PL/SQL隐式地打开SQL游标,并在它内部处理SQL语句,然后关闭它

    2. Oracle的导入导出有几种方式,有何区别? 

    1). 使用oracle工具 exp/imp 

    2). 使用plsql相关工具 

    方法1. 导入/导出的是二进制的数据,

    2.plsql导入/导出的是sql语句的文本文件  

    3. Oracle中有哪几种文件? 

    数据文件(一般后缀为.dbf或者.ora),日志文件(后缀名.log),控制文件(后缀名为.ctl)

    4. 怎样优化Oracle数据库,有几种方式? 

    个人理解,数据库性能最关键的因素在于IO,因为操作内存是快速的,但是读写磁盘是速度很慢的,优化数据库最关键的问题在于减少磁盘的IO,就个人理解应该分为物理的和逻辑的优化, 物理的是指oracle产品本身的一些优化,逻辑优化是指应用程序级别的优化 

    物理优化的一些原则: 

    1). Oracle的运行环境(网络,硬件等) 

    2). 使用合适的优化器 

    3). 合理配置oracle实例参数 

    4). 建立合适的索引(减少IO) 

    5). 将索引数据和表数据分开在不同的表空间上(降低IO冲突) 

    6). 建立表分区,将数据分别存储在不同的分区上(以空间换取时间,减少IO)     

    逻辑上优化: 

    1). 可以对表进行逻辑分割,如中国移动用户表,可以根据手机尾数分成10个表,这样对性能会有一定的作用 

    2). Sql语句使用占位符语句,并且开发时候必须按照规定编写sql语句(如全部大写,全部小写等)oracle解析语句后会放置到共享池中  如: select * from Emp where name=?  这个语句只会在共享池中有一条,而如果是字符串的话,那就根据不同名字存在不同的语句,所以占位符效率较好 

    3). 数据库不仅仅是一个存储数据的地方,同样是一个编程的地方,一些耗时的操作,可以通过存储过程等在用户较少的情况下执行,从而错开系统使用的高峰时间,提高数据库性能 

    4). 尽量不使用*号,如select * from Emp,因为要转化为具体的列名是要查数据字典,比较耗时 

    5). 选择有效的表名  对于多表连接查询,可能oracle的优化器并不会优化到这个程度, oracle 中多表查询是根据FROM字句从右到左的数据进行的,那么最好右边的表(也就是基础表)选择数据较少的表,这样排序更快速,如果有link表(多对多中间表),那么将link表放最右边作为基础表,在默认情况下oracle会自动优化,但是如果配置了优化器的情况下,可能不会自动优化,所以平时最好能按照这个方式编写sql 

    6). Where字句 规则  Oracle 中Where字句时从右往左处理的,表之间的连接写在其他条件之前,能过滤掉非常多的数据的条件,放在where的末尾, 另外!=符号比较的列将不使用索引,列经过了计算(如变大写等)不会使用索引(需要建立起函数), is null、is not null等优化器不会使用索引 

    7). 使用Exits Not Exits 替代 In  Not in 

    8). 合理使用事务,合理设置事务隔离性  数据库的数据操作比较消耗数据库资源的,尽量使用批量处理,以降低事务操作次数  

    5. Oracle分区是怎样优化数据库的? 

    Oracle的分区可以分为:列表分区、范围分区、散列分区、复合分区。 

    1).  增强可用性:如果表的一个分区由于系统故障而不能使用,表的其余好的分区仍可以使用; 

    2).  减少关闭时间:如果系统故障只影响表的一部份分区,那么只有这部份分区需要修复,可能比整个大表修复花的时间更少; 

    3).  维护轻松:如果需要得建表,独产管理每个公区比管理单个大表要轻松得多; 

    4).  均衡I/O:可以把表的不同分区分配到不同的磁盘来平衡I/O改善性能; 

    5).  改善性能:对大表的查询、增加、修改等操作可以分解到表的不同分区来并行执行,可使运行速度更快 

    6).  分区对用户透明,最终用户感觉不到分区的存在。

    6. 解释冷备份和热备份的不同点以及各自的优点? 

    冷备份发生在数据库已经正常关闭的情况下,将关键性文件拷贝到另外位置的一种说法  热备份是在数据库运行的情况下,采用归档方式备份数据的方法 

    冷备的优缺点: 

    1).是非常快速的备份方法(只需拷贝文件)  

    2).容易归档(简单拷贝即可)  

    3).容易恢复到某个时间点上(只需将文件再拷贝回去)  

    4).能与归档方法相结合,作数据库“最新状态”的恢复。  

    5).低度维护,高度安全。  

    冷备份不足:  

    1).单独使用时,只能提供到“某一时间点上”的恢复。  

    2).在实施备份的全过程中,数据库必须要作备份而不能作其它工作。也就是说,在冷备份过程中,数据库必须是关闭状态。  

    3).若磁盘空间有限,只能拷贝到磁带等其它外部存储设备上,速度会很慢。  

    4).不能按表或按用户恢复。    

    热备的优缺点 

    1).可在表空间或数据文件级备份,备份时间短。  

    2).备份时数据库仍可使用。  

    3).可达到秒级恢复(恢复到某一时间点上)。  

    4).可对几乎所有数据库实体作恢复。  

    5).恢复是快速的,在大多数情况下在数据库仍工作时恢复。  

    热备份的不足是:    

    1).不能出错,否则后果严重。    

    2).若热备份不成功,所得结果不可用于时间点的恢复。    

    3).因难于维护,所以要特别仔细小心,不允许“以失败而告终”。 

    展开全文
  • Oracle的常见面试题Oracle的常见面试题Oracle的常见面试题
  • Oracle 面试题汇总

    万次阅读 多人点赞 2019-09-04 20:39:44
    当一个事务修改或删除了共享池持有分析锁的数据库对象时,ORACLE使共享池中的对象作废,下次在引用这条SQL/PLSQL语句时,ORACLE重新分析编译此语句。  4.内部闩锁  内部闩锁 :这是ORACLE中的一种特殊锁,用于顺序...

    1,delete 与Truncate区别?

    1)Truncate 是DDL 语句,DELETE 是DML语句。

    2) Truncate 的速度远快于DELETE;

    原因是: 当执行DELETE操作时所有表数据先被COPY到回滚表空间,数据量不同花费时间长短不一。而TRUNCATE 是直接删除数据不进回滚表空间。

    3) delete 数据可以运行Rollback 进行数据回滚。而Truncate 则是永久删除不能回滚。

    4) Truncate 操作不会触发表上的delete触发器,而delete 会正常触发。

    5) Truncate 语句不能带where 条件意味着只能全部数据删除,而DELETE可带where 条件进行删除数据。

    6) Truncate 操作会重置表的高水位线(High Water Mark),而delete 不会。

     

    2,集合操作符

    Union : 不包含重复值,默认按第一个查询的第一列升序排列。

    Union All : 完全并集包含重复值。不排序。

    Minus 不包含重复值,不排序。

     

    3,数据库的三大范式是什么?

    1) 第一范式:原子件,要求每一列的值不能再拆分了。

    2) 第二范式: 一张表只描述一个实体(若列中有冗余数据,则不满足)

    3)第三范式: 所有列与主键值直接相关。

     

    4 事务的特性(ACID)是指什么?

    1)原子性(Atomic): 事务中的各项操作,要么全做要么全不做,任何一项操作的失败都会导致整个事务的失败。

    2) 一致性(Consistent): 事务结束后系统状态是一样的。

    3)隔离性(Isolated): 并发执行的事务彼此无法看到对方的中间状态。

    4) 持久性(Durable):事务完成后,即使发生灾难性故障,通过日志和同步备份可以在故障发生后重建数据。

    5 Mysql数据库与Oracle 数据库有什么区别?

    1,应用方面,Mysql 是中小型应用的数据库。一般用于个人和中小型企业。Oracle 属于大型数据库,一般用于具有相当规模的企业应用。

    2, 自动增长的数据类型方面: MySQL有自动增长的数据类型。Oracle 没有自动增长的数据类型。需要建立一个自增序列。

    3,group by 用法: Mysql 中group by 在SELECT 语句中可以随意使用,但在ORACLE 中如果查询语句中有组函数,那么其他列必须是组函数处理过的或者是group by子句中的列,否则会报错。

    4,引导方面: MySQL中可以用单引号、双引号包起字符串,Oracle 中只可以用单引号包起字符串

    Oracle跟SQL Server 2005的区别? 

    宏观上: 
    1). 最大的区别在于平台,oracle可以运行在不同的平台上,sql server只能运行在windows平台上,由于windows平台的稳定性和安全性影响了sql server的稳定性和安全性 
    2). oracle使用的脚本语言为PL-SQL,而sql server使用的脚本为T-SQL 
    微观上: 从数据类型,数据库的结构等等回答
     

    7 . 如何使用Oracle的游标? 


    1).  oracle中的游标分为显示游标和隐式游标 
    2).  显示游标是用cursor...is命令定义的游标,它可以对查询语句(select)返回的多条记录进行处理;隐式游标是在执行插入 (insert)、删除(delete)、修改(update)和返回单条记录的查询(select)语句时由PL/SQL自动定义的。 
    3). 显式游标的操作:打开游标、操作游标、关闭游标;PL/SQL隐式地打开SQL游标,并在它内部处理SQL语句,然后关闭它
     

     

    Oracle中function和procedure的区别?

    1). 可以理解函数是存储过程的一种 
    2). 函数可以没有参数,但是一定需要一个返回值,存储过程可以没有参数,不需要返回值 
    3). 函数return返回值没有返回参数模式,存储过程通过out参数返回值, 如果需要返回多个参数则建议使用存储过程 
    4). 在sql数据操纵语句中只能调用函数而不能调用存储过程
     

     

    9 Oracle的导入导出有几种方式,有何区别? 


    1). 使用oracle工具 exp/imp 
    2). 使用plsql相关工具 
    方法1. 导入/导出的是二进制的数据, 2.plsql导入/导出的是sql语句的文本文件 

    3) sqlloader

    4) dblink

     

    10 . 解释冷备份和热备份的不同点以及各自的优点? 


    冷备份发生在数据库已经正常关闭的情况下,将关键性文件拷贝到另外位置的一种说法 
    热备份是在数据库运行的情况下,采用归档方式备份数据的方法 

    冷备的优缺点: 
    1).是非常快速的备份方法(只需拷贝文件)  
    2).容易归档(简单拷贝即可)  
    3).容易恢复到某个时间点上(只需将文件再拷贝回去)  
    4).能与归档方法相结合,作数据库“最新状态”的恢复。  
    5).低度维护,高度安全。  
    冷备份不足:  
    1).单独使用时,只能提供到“某一时间点上”的恢复。  
    2).在实施备份的全过程中,数据库必须要作备份而不能作其它工作。也就是说,在冷备份过程中,数据库必须是关闭状态。  
    3).若磁盘空间有限,只能拷贝到磁带等其它外部存储设备上,速度会很慢。  
    4).不能按表或按用户恢复。  

    热备的优缺点 
    1).可在表空间或数据文件级备份,备份时间短。  
    2).备份时数据库仍可使用。  
    3).可达到秒级恢复(恢复到某一时间点上)。  
    4).可对几乎所有数据库实体作恢复。  
    5).恢复是快速的,在大多数情况下在数据库仍工作时恢复。  
    热备份的不足是:  
      1).不能出错,否则后果严重。  
      2).若热备份不成功,所得结果不可用于时间点的恢复。  
      3).因难于维护,所以要特别仔细小心,不允许“以失败而告终”。 
     

     

    11 解释data block , extent 和 segment的区别? 

    data block 数据块,是oracle最小的逻辑单位,通常oracle从磁盘读写的就是块 
    extent 区,是由若干个相邻的block组成 
    segment段,是有一组区组成 
    tablespace表空间,数据库中数据逻辑存储的地方,一个tablespace可以包含多个数据文件 
     

    12. 解释什么是死锁,如何解决Oracle中的死锁? 


    简言之就是存在加了锁而没有解锁,可能是使用锁没有提交或者回滚事务,如果是表级锁则不能操作表,客户端处于等在状态,如果是行级锁则不能操作锁定行 


    解决办法: 
    1). 查找出被锁的表 
    select b.owner,b.object_name,a.session_id,a.locked_mode 
    from v$locked_object a,dba_objects b 
    where b.object_id = a.object_id; 
         
    select b.username,b.sid,b.serial#,logon_time 
    from v$locked_object a,v$session b 
    where a.session_id = b.sid order by b.logon_time; 

    2). 杀进程中的会话 

    alter system kill session "sid,serial#"; 
     

    13  简述oracle中 dml、ddl、dcl的使用 

    Dml 数据操纵语言,如select、update、delete,insert 
    Ddl 数据定义语言,如create table 、drop table 等等 
    Dcl 数据控制语言, 如 commit、 rollback、grant、 invoke等 

     

    14 怎样创建一个一个索引,索引使用的原则,有什么优点和缺点 

     

    创建标准索引: 
    CREATE  INDEX 索引名 ON 表名 (列名)  TABLESPACE 表空间名; 
    创建唯一索引: 
    CREATE unique INDEX 索引名 ON 表名 (列名)  TABLESPACE 表空间名; 
    创建组合索引: 
    CREATE INDEX 索引名 ON 表名 (列名1,列名2)  TABLESPACE 表空间名; 
    创建反向键索引: 
    CREATE INDEX 索引名 ON 表名 (列名) reverse TABLESPACE 表空间名; 
    索引使用原则: 
    索引字段建议建立NOT NULL约束 
    经常与其他表进行连接的表,在连接字段上应该建立索引; 
    经常出现在Where子句中的字段且过滤性很强的,特别是大表的字段,应该建立索引; 
    可选择性高的关键字 ,应该建立索引; 
    可选择性低的关键字,但数据的值分布差异很大时,选择性数据比较少时仍然可以利用索引提高效率 
    复合索引的建立需要进行仔细分析;尽量考虑用单字段索引代替: 
    A、正确选择复合索引中的第一个字段,一般是选择性较好的且在where子句中常用的字段上; 
    B、复合索引的几个字段经常同时以AND方式出现在Where子句中可以建立复合索引;否则单字段索引; 
    C、如果复合索引中包含的字段经常单独出现在Where子句中,则分解为多个单字段索引; 
    D、如果复合索引所包含的字段超过3个,那么仔细考虑其必要性,考虑减少复合的字段; 
    E、如果既有单字段索引,又有这几个字段上的复合索引,一般可以删除复合索引; 
    频繁DML的表,不要建立太多的索引; 
    不要将那些频繁修改的列作为索引列; 
    索引的优缺点: 
    有点: 
    1. 创建唯一性索引,保证数据库表中每一行数据的唯一性 
    2. 大大加快数据的检索速度,这也是创建索引的最主要的原因 
    3. 加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。 
    4. 在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序的时间。 
    缺点: 
    1. 索引创建在表上,不能创建在视图上 
    2. 创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加 
    3. 索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果要建立聚簇索引,那么需要的空间就会更大 
    4. 当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,降低了数据的维护速度 

    15 oracle的锁又几种,定义分别是什么;

     

    1.  行共享锁 (ROW SHARE) 
    2.  行排他锁(ROW EXCLUSIVE) 
    3 . 共享锁(SHARE) 
    4.  共享行排他锁(SHARE ROW EXCLUSIVE) 
    5.  排他锁(EXCLUSIVE) 

    使用方法: 
    SELECT * FROM order_master WHERE vencode="V002" 
    FOR UPDATE WAIT 5; 
    LOCK TABLE order_master IN SHARE MODE; 
    LOCK TABLE itemfile IN EXCLUSIVE MODE NOWAIT; 
    ORACLE锁具体分为以下几类: 
    1.按用户与系统划分,可以分为自动锁与显示锁 
    自动锁:当进行一项数据库操作时,缺省情况下,系统自动为此数据库操作获得所有有必要的锁。 
    显示锁:某些情况下,需要用户显示的锁定数据库操作要用到的数据,才能使数据库操作执行得更好,显示锁是用户为数据库对象设定的。 
    2 . 按锁级别划分,可分为共享锁与排它锁 
    共享锁:共享锁使一个事务对特定数据库资源进行共享访问——另一事务也可对此资源进行访问或获得相同共享锁。共享锁为事务提供高并发性,但如拙劣的事务设计+共享锁容易造成死锁或数据更新丢失。 
    排它锁:事务设置排它锁后,该事务单独获得此资源,另一事务不能在此事务提交之前获得相同对象的共享锁或排它锁。 
    3.按操作划分,可分为DML锁、DDL锁 
    DML锁又可以分为,行锁、表锁、死锁 
    行锁:当事务执行数据库插入、更新、删除操作时,该事务自动获得操作表中操作行的排它锁。 
    表级锁:当事务获得行锁后,此事务也将自动获得该行的表锁(共享锁),以防止其它事务进行DDL语句影响记录行的更新。事务也可以在进行过程中获得共享锁或排它锁,只有当事务显示使用LOCK TABLE语句显示的定义一个排它锁时,事务才会获得表上的排它锁,也可使用LOCK TABLE显示的定义一个表级的共享锁(LOCK TABLE具体用法请参考相关文档)。 
    死锁:当两个事务需要一组有冲突的锁,而不能将事务继续下去的话,就出现死锁。 
    如事务1在表A行记录#3中有一排它锁,并等待事务2在表A中记录#4中排它锁的释放,而事务2在表A记录行#4中有一排它锁,并等待事务; 1在表A中记录#3中排它锁的释放,事务1与事务2彼此等待,因此就造成了死锁。死锁一般是因拙劣的事务设计而产生。死锁只能使用SQL下:alter system kill session "sid,serial#";或者使用相关操作系统kill进程的命令,如UNIX下kill -9 sid,或者使用其它工具杀掉死锁进程。 
    DDL锁又可以分为:排它DDL锁、共享DDL锁、分析锁 
    排它DDL锁:创建、修改、删除一个数据库对象的DDL语句获得操作对象的 排它锁。如使用alter table语句时,为了维护数据的完成性、一致性、合法性,该事务获得一排它DDL锁。 
    共享DDL锁:需在数据库对象之间建立相互依赖关系的DDL语句通常需共享获得DDL锁。 
    如创建一个包,该包中的过程与函数引用了不同的数据库表,当编译此包时,该事务就获得了引用表的共享DDL锁。 
    分析锁:ORACLE使用共享池存储分析与优化过的SQL语句及PL/SQL程序,使运行相同语句的应用速度更快。一个在共享池中缓存的对象获得它所引用数据库对象的分析锁。分析锁是一种独特的DDL锁类型,ORACLE使用它追踪共享池对象及它所引用数据库对象之间的依赖关系。当一个事务修改或删除了共享池持有分析锁的数据库对象时,ORACLE使共享池中的对象作废,下次在引用这条SQL/PLSQL语句时,ORACLE重新分析编译此语句。 
    4.内部闩锁 
    内部闩锁:这是ORACLE中的一种特殊锁,用于顺序访问内部系统结构。当事务需向缓冲区写入信息时,为了使用此块内存区域,ORACLE首先必须取得这块内存区域的闩锁,才能向此块内存写入信息。
     

     

     

     

     

     

     

     

     

     

     

     

     

    展开全文
  • oarcle java 面试题 答案 Java面试 Oracle面试
  • 2013oracle面试题

    热门讨论 2013-10-27 15:55:58
    2013oracle面试题,题目解法请登录我的博客 http://blog.csdn.net/itcastcpp 查看
  • Oracle面试题及答案整理

    千次阅读 2019-07-09 17:57:00
    Oracle数据库程序包中的变量,在本程序包中可以直接引用,但是在程序包之外,则不可以直接引用。对程序包变量的存取,可以为每个变量配套相应的存储过程 < 用于存储数据 > 和函数 < 用于读取数据 > 来实现。     ...

    一下题目根据此表变换

    1、表:table1(FId,Fclass,Fscore),用最高效最简单的SQL列出各班成绩最高的列表,显示班级,成绩两个字段。

     select stu_class, max(stu_score) from core group by stu_class ;

    2、有一个表table1有两个字段FID,Fno,字都非空,写一个SQL语句列出该表中一个FID对应多个不同的Fno的纪录。

    select t2.* from table1 t1, table1 t2 where t1.fid = t2.fid and t1.fno <> t2.fno;

    三种写法:

    select * from core co1 where co1.STU_CLASS in ( select co.STU_CLASS from CORE co group by co.STU_CLASS  having count(co.STU_CLASS) >1);
     
     select DISTINCT c2.* from core c1 ,core c2 where c1.STU_CLASS = c2.STU_CLASS and c1.STU_SCORE <> c2.STU_SCORE;
     SELECT * FROM core c1 where 1=1 and  EXISTS (select 1 from core c2 where c1.STU_CLASS = c2.STU_CLASS and c1.STU_SCORE <> c2.STU_SCORE);          

     3、有员工表empinfo 

    Fempno varchar2(10) not null pk, 
    Fempname varchar2(20) not null, 
    Fage number not null, 
    Fsalary number not null 
    ); 
    假如数据量很大约1000万条;写一个你认为最高效的SQL,用一个SQL计算以下四种人: 
    fsalary>9999 and fage > 35 
    fsalary>9999 and fage < 35 
    fsalary <9999 and fage > 35 
    fsalary <9999 and fage < 35 
    每种员工的数量; 

    select sum(case when fsalary > 9999 and fage > 35
    then 1
    else 0end) as "fsalary>9999_fage>35",
    sum(case when fsalary > 9999 and fage < 35
    then 1
    else 0
    end) as "fsalary>9999_fage<35",
    sum(case when fsalary < 9999 and fage > 35
    then 1
    else 0
    end) as "fsalary<9999_fage>35",
    sum(case when fsalary < 9999 and fage < 35
    then 1
    else 0
    end) as "fsalary<9999_fage<35"
    from empinfo;

     

    select 
    sum(case when stu_score < 60 then 1 else 0 end ) as "60分以下人数" ,
    sum(case when stu_score > 60 and stu_score <= 70 then 1 else 0 end ) as "60到70分人数" ,
    sum(case when stu_score > 70 and stu_score <= 80 then 1 else 0 end ) as "70到80分人数" ,
    sum(case when stu_score > 80 and stu_score <= 100 then 1 else 0 end ) as "80分以上人数" 
    from core;

    4、表A字段如下 
    month person income 
    月份 人员 收入 
    要求用一个SQL语句(注意是一个)的处所有人(不区分人员)每个月及上月和下月的总收入 
    要求列表输出为 
    月份 当月收入 上月收入 下月收入 
    MONTHS PERSON INCOME
    ---------- ---------- ----------200807 mantisXF 5000200806 mantisXF2 3500200806 mantisXF3 3000200805 mantisXF1 2000200805 mantisXF6 2200200804 mantisXF7 1800200803 8mantisXF 4000200802 9mantisXF 4200200802 10mantisXF 3300200801 11mantisXF 4600200809 11mantisXF 6800
    11 rows selected

    select months, max(incomes), max(prev_months), max(next_months)
    from (select months,
    incomes,
    decode(lag(months) over(order by months),
    to_char(add_months(to_date(months, 'yyyymm'), -1), 'yyyymm'), lag(incomes) over(order by months), 0) as prev_months, decode(lead(months) over(order by months), to_char(add_months(to_date(months, 'yyyymm'), 1), 'yyyymm'), lead(incomes) over(order by months), 0) as next_months from (select months, sum(income) as incomes from a group by months) aa) aaagroup by months;
    
    MONTHS MAX(INCOMES) MAX(PREV_MONTHS) MAX(NEXT_MONTHS)

    ---------- ------------ ---------------- ----------------200801 4600 0 7500200802 7500 4600 4000200803 4000 7500 1800200804 1800 4000 4200200805 4200 1800 6500200806 6500 4200 5000200807 5000 6500 0200809 6800 0 0

    5,表B 
    C1 c2 
    2005-01-01 1 
    2005-01-01 3 
    2005-01-02 5

    要求的处数据 
    2005-01-01 4 
    2005-01-02 5 
    合计 9 
    试用一个Sql语句完成。

     

    select nvl(to_char(t02,'yyyy-mm-dd'),'合计'),sum(t01)from test 
    group by rollup(t02)

    6,数据库1,2,3 范式的概念与理解。

    关系数据库设计之时是要遵守一定的规则的。尤其是数据库设计范式 
    简单介绍1NF(第一范式),2NF(第二范式),3NF(第三范式),
    第一范式(1NF):在关系模式R中的每一个具体关系r中,如果每个属性值 都是不可再分的最小数据单位,则称R是第一范式的关系。
    例:如职工号,姓名,电话号码组成一个表(一个人可能有一个办公室电话 和一个家里电话号码) 规范成为1NF有三种方法: 
      一是重复存储职工号和姓名。这样,关键字只能是电话号码。 
      二是职工号为关键字,电话号码分为单位电话和住宅电话两个属性 
      三是职工号为关键字,但强制每条记录只能有一个电话号码。 
      以上三个方法,第一种方法最不可取,按实际情况选取后两种情况。 
     第二范式(2NF):如果关系模式R(U,F)中的所有非主属性都完全依赖于任意一个候选关键字,则称关系R 是属于第二范式的。 
      例:选课关系 SCI(SNO,CNO,GRADE,CREDIT)其中SNO为学号, CNO为课程号,GRADEGE 为成绩,CREDIT 为学分。 由以上 
    条件,关键字为组合关键字(SNO,CNO) 
      在应用中使用以上关系模式有以下问题: 
      a.数据冗余,假设同一门课由40个学生选修,学分就 重复40次。 
      b.更新异常,若调整了某课程的学分,相应的元组CREDIT值都要更新,有可能会出现同一门课学分不同。 
      c.插入异常,如计划开新课,由于没人选修,没有学号关键字,只能等有人选修才能把课程和学分存入。 
      d.删除异常,若学生已经结业,从当前数据库删除选修记录。某些门课程新生尚未选修,则此门课程及学分记录无法保存。 
      原因:非关键字属性CREDIT仅函数依赖于CNO,也就是CREDIT部分依赖组合关键字(SNO,CNO)而不是完全依赖。 
      解决方法:分成两个关系模式 SC1(SNO,CNO,GRADE),C2(CNO,CREDIT)。新关系包括两个关系模式,它们之间通过SCN中
    的外关键字CNO相联系,需要时再进行自然联接,恢复了原来的关系 
     第三范式(3NF):如果关系模式R(U,F)中的所有非主属性对任何候选关键字都不存在传递信赖,则称关系R是属于第三范式的。 
      例:如S1(SNO,SNAME,DNO,DNAME,LOCATION) 各属性分别代表学号, 
      姓名,所在系,系名称,系地址。 
      关键字SNO决定各个属性。由于是单个关键字,没有部分依赖的问题,肯定是2NF。但这关系肯定有大量的冗余,有关学生所在的几个
    属性DNO,DNAME,LOCATION将重复存储,插入,删除和修改时也将产生类似以上例的情况。 
      原因:关系中存在传递依赖造成的。即SNO -> DNO。 而DNO -> SNO却不存在,DNO -> LOCATION, 因此关键辽 SNO 对 LOCATIO
    N 函数决定是通过传递依赖 SNO -> LOCATION 实现的。也就是说,SNO不直接决定非主属性LOCATION。 
      解决目地:每个关系模式中不能留有传递依赖。 
      解决方法:分为两个关系 S(SNO,SNAME,DNO),D(DNO,DNAME,LOCATION) 
      注意:关系S中不能没有外关键字DNO。否则两个关系之间失去联系。

    7,简述oracle行触发器的变化表限制表的概念和使用限制,行触发器里面对这两个表有什么限制。

    变化表mutating table
    被DML语句正在修改的表
    需要作为DELETE CASCADE参考完整性限制的结果进行更新的表也是变化的

    限制:对于Session本身,不能读取正在变化的表

    限制表constraining table
    需要对参考完整性限制执行读操作的表

    限制:如果限制列正在被改变,那么读取或修改会触发错误,但是修改其它列是允许的。

    8、oracle临时表有几种。 
    临时表和普通表的主要区别有哪些,使用临时表的主要原因是什么?

    在Oracle中,可以创建以下两种临时表: 
    a。会话特有的临时表 
    CREATE GLOBAL TEMPORARY ( ) 
    ON COMMIT PRESERVE ROWS;

    b。事务特有的临时表 
    CREATE GLOBAL TEMPORARY ( ) 
    ON COMMIT DELETE ROWS; 
    CREATE GLOBAL TEMPORARY TABLE MyTempTable 
    所建的临时表虽然是存在的,但是你试一下insert 一条记录然后用别的连接登上去select,记录是空的,明白了吧。
    下面两句话再贴一下: 
    --ON COMMIT DELETE ROWS 说明临时表是事务指定,每次提交后ORACLE将截断表(删除全部行) 
    --ON COMMIT PRESERVE ROWS 说明临时表是会话指定,当中断会话时ORACLE将截断表。

    9,怎么实现:使一个会话里面执行的多个过程函数或触发器里面都可以访问的全局变量的效果,并且要实现会话间隔离?

    --个人理解就是建立一个包,将常量或所谓的全局变量用包中的函数返回出来就可以了,摘抄一短网上的解决方法
    Oracle数据库程序包中的变量,在本程序包中可以直接引用,但是在程序包之外,则不可以直接引用。对程序包变量的存取,可以为每个变量配套相应的存储过程<用于存储数据>和函数<用于读取数据>来实现。 
      
      3.2 实例 
      --定义程序包 
      create or replace package PKG_System_Constant is 
      
        C_SystemTitle nVarChar2(100):='测试全局程序变量'; --定义常数 
        --获取常数<系统标题> 
        Function FN_GetSystemTitle 
         Return nVarChar2; 
      
        G_CurrentDate Date:=SysDate; --定义全局变量 
        --获取全局变量<当前日期> 
        Function FN_GetCurrentDate 
         Return Date; 
        --设置全局变量<当前日期> 
        Procedure SP_SetCurrentDate 
         (P_CurrentDate In Date); 
      End PKG_System_Constant; 
      / 
      create or replace package body PKG_System_Constant is 
        --获取常数<系统标题> 
        Function FN_GetSystemTitle 
         Return nVarChar2 
         Is 
         Begin 
           Return C_SystemTitle; 
         End FN_GetSystemTitle; 
      
        --获取全局变量<当前日期> 
        Function FN_GetCurrentDate 
         Return Date 
         Is 
         Begin 
           Return G_CurrentDate; 
         End FN_GetCurrentDate; 
        --设置全局变量<当前日期> 
        Procedure SP_SetCurrentDate 
         (P_CurrentDate In Date) 
         Is 
         Begin 
           G_CurrentDate:=P_CurrentDate; 
         End SP_SetCurrentDate; 
      End PKG_System_Constant; 
      / 
        
      3.3 测试 
      --测试读取常数 
      Select PKG_System_Constant.FN_GetSystemTitle From Dual;    
      --测试设置全局变量 
      Declare 
      Begin 
        PKG_System_Constant.SP_SetCurrentDate(To_Date('2001.01.01','yyyy.mm.dd')); 
      End; 
      / 
      --测试读取全局变量 
      Select PKG_System_Constant.FN_GetCurrentDate From Dual;

    10,aa,bb表都有20个字段,且记录数量都很大,aa,bb表的X字段(非空)上有索引, 
    请用SQL列出aa表里面存在的X在bb表不存在的X的值,请写出认为最快的语句,并解译原因。

    select aa.x from aa
    where not exists (select 'x' from bb where aa.x = bb.x) ;
    以上语句同时使用到了aa中x的索引和的bb中x的索引

    11,简述SGA主要组成结构和用途?

    SGA是Oracle为一个实例分配的一组共享内存缓冲区,它包含该实例的数据和控制信息。SGA在实例启动时被自动分配,当实例关闭时被收回。数据库的所有数据操作都要通过SGA来进行。 
    SGA中内存根据存放信息的不同,可以分为如下几个区域:
    a.Buffer Cache:存放数据库中数据库块的拷贝。它是由一组缓冲块所组成,这些缓冲块为所有与该实例相链接的用户进程所共享。缓冲块的数目由初始化参数DB_BLOCK_BUFFERS确定,缓冲块的大小由初始化参数DB_BLOCK_SIZE确定。大的数据块可提高查询速度。它由DBWR操作。 
    b. 日志缓冲区Redo Log Buffer:存放数据操作的更改信息。它们以日志项(redo entry)的形式存放在日志缓冲区中。当需要进行数据库恢复时,日志项用于重构或回滚对数据库所做的变更。日志缓冲区的大小由初始化参数LOG_BUFFER确定。大的日志缓冲区可减少日志文件I/O的次数。后台进程LGWR将日志缓冲区中的信息写入磁盘的日志文件中,可启动ARCH后台进程进行日志信息归档。 
    c. 共享池Shared Pool:包含用来处理的SQL语句信息。它包含共享SQL区和数据字典存储区。共享SQL区包含执行特定的SQL语句所用的信息。数据字典区用于存放数据字典,它为所有用户进程所共享。

    12什么是分区表?简述范围分区和列表分区的区别,分区表的主要优势有哪些?

    使用分区方式建立的表叫分区表

    范围分区 
    每个分区都由一个分区键值范围指定(对于一个以日期列作为分区键的表,“2005 年 1 月”分区包含分区键值为从“2005 年 1 月 1 日” 
    到“2005 年 1 月 31 日”的行)。

    列表分区 
    每个分区都由一个分区键值列表指定(对于一个地区列作为分区键的表,“北美”分区可能包含值“加拿大”“美国”和“墨西哥”)。

    分区功能通过改善可管理性、性能和可用性,从而为各式应用程序带来了极大的好处。通常,分区可以使某些查询以及维护操作的性能大大提高。此外,分区还可以极大简化常见的管理任务。通过分区,数据库设计人员和管理员能够解决前沿应用程序带来的一些难题。分区是构建千兆字节数据系统或超高可用性系统的关键工具。

    13,背景:某数据运行在archivelog,且用rman作过全备份和数据库的冷备份, 
    且所有的归档日志都有,现控制文件全部损坏,其他文件全部完好,请问该怎么恢复该数据库,说一两种方法。

    回复的方法:
    一.使用冷备份,直接将冷备份的文件全部COPY到原先的目录下,在从新启动数据库就可以
    二.使用归档日志,
    1.启动数据库NOMOUNT
    2.创建控制文件,控制文件指定数据文件和重做日志文件的位置.
    3.使用RECOVER DATABASE using backup controlfile until cancel 命令回复数据库,这时可以使用归档日志
    4.ALETER DATABASE OPEN RESETLOGS;
    5.重新备份数据库和控制文件

    14,用rman写一个备份语句:备份表空间TSB,level 为2的增量备份。

    15,有个表a(x number(20),y number(20))用最快速高效的SQL向该表插入从1开始的连续的1000万记录。

    转载于:https://www.cnblogs.com/lukelook/p/11159053.html

    展开全文
  • Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题Oracle 面试题...
  • Oracle推出它的主要目的就是为了降低在并行服务器(Oracle Parallel Server)环境下索引叶块的争用。当B Tree索引中有一列是由递增的序列号产生的话,那么这些索引信息基本上分布在同一个叶块,当用户修改或访问相似...
  • Oracle面试题.doc

    2021-10-08 22:19:24
    Oracle面试题.doc
  • Oracle数据库DBA面试题50道及答案; 想面试oracle岗位的可以下载看下; 本人资源分不多,谢谢支持!

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 30,105
精华内容 12,042
关键字:

oracle面试题