♣ 题目部分 在Oracle中,Oracle的DBLINK是什么?...♣ 答案部分 当用户要跨本地数据库访问另外一个数据库表中的数据时,本地数据库中必须创建了远程数据库的DBLINK,通过DBLINK可以像访问本地数据库一样访问远程数据库表中的数据。...其实,DBLINK和数据库中的VIEW差不多,创建DBLINK的时候需要知道待读取数据库的IP地址、ORACLE_SID以及数据库用户名和密码。.../密码,然后在本地数据库中通过DBLINK访问远程数据库“TNS_BJLHR”中SCOTT.TB_TEST表,SQL语句如下所示: SELECT * FROM SCOTT.TB_TEST@DBL_BJLHR...; 创建DBLINK的第二种方式,是在本地数据库tnsnames.ora文件中没有配置要访问的远程数据库的时候,而直接将相关的内容写到DBLINK的配置中,如下所示: CREATE DATABASE LINK
♣ 题目部分 在Oracle中,SCN是什么? ♣ 答案部分 SCN(System Change Number,系统改变号)是一个由系统内部维护的序列号,在数据库全局是唯一的。...当系统需要更新的时候自动增加,它是系统中维持数据的一致性和顺序恢复的重要标志,是数据库中非常重要的一种数据结构。...SCN是在某个时间点定义数据库已提交版本的时间戳标记,Oracle为每个已提交的事务分配一个唯一的SCN。SCN的值是对数据库进行更改的逻辑时间点。SCN是一个只会增加、不会减少的数字。...由于SCN描述的是数据一致性的状态,所以,它会在各种涉及数据一致性的场合中起到重要作用。...本文选自《Oracle程序员面试笔试宝典》,作者:小麦苗 ?
♣ 题目部分 在Oracle中,LogMiner是什么?其有哪些用途?请简述LogMiner的使用过程。...♣ 答案部分 众所周知,所有对用户数据和数据字典的改变都记录在Oracle的Redo日志中,因此,Redo日志包含了所有进行恢复操作所需要的信息。...但是,原始的Redo日志文件无法看懂,所以,Oracle从8i以后提供了一个非常有用的分析工具,称为LogMiner。使用该工具可以轻松获得Redo日志文件(包含归档日志文件)中的具体内容。...6、执行后续审计 (一)安装LogMiner工具 在默认情况下,Oracle已经安装了LogMiner工具。...确保在创建Flat File文件的过程中,不能有DDL操作被执行。
♣ 题目部分 在Oracle中,压缩索引是什么? ♣ 答案部分 Oracle数据库可以使用键压缩(Key Compression)来压缩B-Tree索引或索引组织表中的主键列值的部分。...键压缩可以大大减少索引所使用的空间,使用了键压缩的索引称为压缩索引。对索引进行压缩更多的意义在于节省存储空间,减少I/O时间。...压缩也是会引入存储开销的,只是很多时候压缩节省的空间比压缩需要的存储开销更大,所以压缩以后整体的存储开销减小了。...可以使用如下的SQL将索引重建为压缩或非压缩的索引: ALTER INDEX EMPLOYEE_LAST_NAME_IDX REBUILD NOCOMPRESS;--非压缩 ALTER INDEX EMPLOYEE_LAST_NAME_IDX...'; 本文选自《Oracle程序员面试笔试宝典》,作者:李华荣。
♣ 题目部分 在Oracle中,位图索引是什么? ♣ 答案部分 位图索引(Bitmap Indexes)是一种使用位图的特殊数据库索引。它针对大量相同值的列而创建,例如:类别、型号等。...,以及这些键值的位置编码,位置编码中的每一位表示键值对应的数据行的有无。一个块可能指向的是几十甚至成百上千行数据的位置。 在位图索引中,数据库为每个索引键存储一个位图。...在传统的B-Tree索引中,一个索引条目指向单个行,但是在位图索引中,每个索引键存储指向多个行的指针。相对于B-Tree索引,位图索引占用的空间非常小,创建和使用速度非常快。...创建位图索引的语法很简单,就是在普通索引创建的语法中的INDEX前加关键字BITMAP即可,如下所示: CREATE BITMAP INDEX IDX_SEX_LHR ON T_USER(SEX); 关于位图索引...可以使用如下的SQL语句查询数据库中的所有位图索引: SELECT * FROM DBA_INDEXES D WHERE D.INDEX_TYPE='BITMAP'; 本文选自《Oracle程序员面试笔试宝典
♣ 题目部分 在Oracle中,函数索引是什么?...♣ 答案部分 在Oracle中,有一类特殊的索引,称为函数索引(Function-Based Indexes,FBI),它基于对表中列进行计算后的结果创建索引。...函数索引在不修改应用程序的逻辑基础上提高了查询性能。如果没有函数索引,那么任何在列上执行了函数的查询都不能使用这个列的索引。当在查询中包含该函数时,数据库才会使用该函数索引。...② 如果被函数索引所引用的用户自定义PL/SQL函数失效了或该函数索引的属主没有了在函数索引里面使用的函数的执行权限,那么对这张表上的执行的所有的操作(例如SELECT查询、DML等)也将失败(会报错:...③ 创建函数索引的函数必须是确定性的。即,对于指定的输入,总是会返回确定的结果。 ④ 在创建索引的函数里面不能使用SUM、COUNT等聚合函数。
题目部分 如何查找或监控效率低下的SQL语句?在Oracle中,errorstack的作用是什么?...答案部分 在使用Oracle数据库的过程中,可能会遇到各种各样的错误或异常,而且这些错误或异常的提示并不具体,那么这个时候就可以使用Oracle提供的一种对于错误堆栈进行跟踪的方法即errorstack...,也可以在参数文件中设置,这个设置仅当某个特定的错误出现时才被触发,如设置ORA-01438事件的跟踪: alter system set events '1438 trace name errorstack...forever,level 3';--启用 ...执行SQL语句... alter system set events '1438 trace name errorstack off';--关闭 接下来在告警日志中找到相关的跟踪文件...本文选自《Oracle程序员面试笔试宝典》,作者:小麦苗
Q 题目 在Oracle中,实例恢复和介质恢复的区别是什么? A 答案 Redo日志是Oracle为确保已经提交的事务不会丢失而建立的一种机制。...但是,这些数据文件可能还包含未提交的更改,要么是在实例失败前保存到数据文件中的,或者是在前滚过程中引入的。...Oracle数据库使用检查点位置,保证每个低于其SCN的已提交更改都已保存到磁盘。Oracle数据库应用Undo块,以回滚数据块中在实例失败前写入的或前滚过程中引入的未提交更改。...Oracle数据库应用Undo块回滚在数据块中未提交的改变,这些数据块是在实例失败之前或者前滚期间被写入的。回滚会将已执行但尚未提交的更改会返回到初始状态。...操作对应的Undo信息(在Buffer Cache生成对应中的Undo Block)就会首先生成其对应的Redo信息(Undo Block's Redo Entry)并写入Log Buffer中。
♣ 题目部分 在Oracle中,V$SESSION_LONGOPS视图的作用是什么?...♣ 答案部分 在Oracle 11g之前的版本,长时间运行的SQL可以通过监控VSESSION_LONGOPS来观察,当某个操作执行时间超过6秒时,就会被记录在VSESSION_LONGOPS中,通常可以监控到全表扫描...SESSION_LONGOPS A WHERE A.TIME_REMAINING 0 ORDER BY A.TIME_REMAINING DESC, A.SQL_ID, A.SID; 本文选自《Oracle
♣ 题目部分 在Oracle中,Oracle Cluster Health Monitor(CHM)的作用是什么?...在Oracle 11.2.0.3之后,AIX和Linux平台在安装Grid时默认安装CHM。...manage -get repsize #查看CHM数据保留时间(s) oclumon manage -repos resize 68083 #修改CHM数据保留时间(s) 在集群中,可以通过下面的命令查看...00:01:31 /u01/app/11.2.0/grid/bin/osysmond.bin 2、Cluster Logger Service(ologgerd):在一个集群中,ologgerd会有一个主节点...当ologgerd在当前的节点遇到问题而无法启动后,它会在备用节点启用。该服务会将osysmond收集的数据保存到CHM资料库中($GRID_HOME/crf/db)。
♣ 题目部分 在Oracle中,位图连接索引是什么? ♣ 答案部分 位图连接索引(Bitmap Join Indexes)是建立在两个或更多表的连接之上的位图索引。...对于表列中的每个值,索引存储被索引表中的相应行的ROWID。相比之下,在标准位图索引中,索引是建立在一个表上的。在数据仓库环境中使用这种索引可以改进连接维度表和事实表的查询性能。...创建位图连接索引时,标准方法是连接索引中常用的维度表(Dimension)和事实表(Fact)。当用户在一次查询中结合查询事实表和维度表时,就不需要执行连接,因为在位图连接索引中已经有可用的连接结果。...位图连接索引有如下几点限制: ① 只可以索引维度表中的列。 ② 用于连接的列必须是维度表中的主键或唯一约束;如果是复合主键,那么必须使用连接中的每一列。...本文选自《Oracle程序员面试笔试宝典》,作者:李华荣。
♣ 题目部分 【DB笔试面试826】在Oracle中,ASH和AWR的关系是什么?...♣ 答案部分 自Oracle 10g开始,Oracle会将处于等待状态的会话的相关信息复制一份到VSESSION_WAIT中,而VSESSION_WAIT_HISTORY是其归档表,但这个表只会保存VSESSION_WAIT...ASH采用的策略是:保存处于等待状态的活动SESSION的信息,每秒从V$SESSION_WAIT中采样一次,并将采样信息保存在内存中。...这样,对于长期检测Oracle的性能是不可能的。在Oracle 10g中,提供了永久保留ASH信息的方法,这就是AWR。...由于全部保存ASH中的信息是非常耗费时间和空间的,AWR采用的策略是:每小时对VACTIVE_SESSION_HISTORY进行采样一次,并将信息保存到磁盘中。
题目 在Oracle中,SESSIONS和PROCESSES的关系是什么? 答案 在数据库安装完成后,常常需要设置SESSIONS和PROCESSES的大小。...其中,SESSIONS指定了一个实例中允许的会话数,即能同时登录到数据库的并发用户数。PROCESSES指定了一个实例在操作系统级别能同时运行的进程数,包括后台进程与服务器进程。...通过查找官方文档,可以知道SESSIONS参数的值在Oracle 10g和11g中是不同的,如下表所示: 属性Oracle 10gOracle 11gR2参数值的类型IntegerInteger默认值Derived...: (1.1 * PROCESSES) + 5Derived: (1.5 * PROCESSES) + 22是否可以动态修改NoNo范围1 to 2311 to 216 (即1到65536)注:在Oracle...在Oracle 11gR2以下版本中,SESSIONS大小的计算公式为:(1.1 * PROCESSES) + 5;在Oracle 11gR2中,SESSIONS大小的计算公式为:(1.5 * PROCESSES
♣ 题目部分 在Oracle中,cvuqdisk包的作用是什么?...♣ 答案部分 在安装RAC的过程中,如果没有安装cvuqdisk包,那么集群检验工具(Cluster Verification Utility,CVU)就不能发现共享磁盘。...cvuqdisk的RPM包含在Oracle Grid Infrastructure安装介质上的rpm目录中。...以root用户在RAC的2个节点上都进行安装,如下: export CVUQDISK_GRP=oinstall rpm -iv cvuqdisk-1.0.9-1.rpm & 说明: 有关cvuqdisk...的更多内容可以参考我的BLOG:http://blog.itpub.net/26736162/viewspace-2136390/ 本文选自《Oracle程序员面试笔试宝典》,作者:小麦苗
♣题目部分在Oracle中,SELECT ... FOR UPDATE加的是什么锁? ♣答案部分 SELECT ... FOR UPDATE语句的语法如下: SELECT ......FOR UPDATE [OF column_list][WAIT n|NOWAIT][SKIP LOCKED]; 其中,这个OF子句在涉及到多个表时,具有较大作用。...“使用FOR UPDATE WAIT”子句的优点如下: ① 防止无限期地等待被锁定的行 ② 允许应用程序中对锁的等待时间进行更多的控制 ③ 对于交互式应用程序非常有用,因为这些用户不能等待不确定的时间...④ 若使用了SKIP LOCKED,则可以越过锁定的行,不会报告由wait n引发的“资源忙”异常报告 在Oracle 10g之前,SELECT ......FOR UPDATE获取的是2级TM锁,而从Oracle 10g开始,SELECT ... FOR UPDATE获取的是3级TM锁。 本文选自《Oracle程序员面试笔试宝典》,作者:小麦苗
Oracle中,当需要建立一个自增字段时,需要用到sequence。...sequence也可以在mysql中使用,但是有些差别,日后再补充,先把oracle中sequence的基本使用总结一下,方便日后查阅。
♣ 题目部分 在Oracle中,cluvfy工具的作用是什么?...♣ 答案部分 cluvfy(Cluster Verification Utility,集群检验工具),简称CVU,是随Oracle集群管理软件一起发布的检查工具。...它的功能是对整个集群系统实施过程的各个阶段以及各个组件进行检查,并验证是否满足Oracle的要求。...cluvfy在进行检查时并不会修改系统配置,所以不会对系统造成影响。cluvfy检查的内容可以从两个角度进行分类:阶段(stage)、组件(component)。...& 说明: 有关CVU的更多内容可以参考我的BLOG:http://blog.itpub.net/26736162/viewspace-2136390/ 本文选自《Oracle程序员面试笔试宝典》,作者
♣ 题目部分 在Oracle中,RAC中REMOTE_LISTENER的作用是什么?...♣ 答案部分 REMOTE_LISTENER参数主要用于RAC环境中监听器的远程注册,监听器的远程注册主要用于实现负载均衡。...在启用了负载均衡的情形下,Master Instance会将请求转发到负载较小的实例。...在RAC环境下不管是使用了默认的TCP和1521还是其他协议都建议配置LOCAL_LISTENER。REMOTE_LISTENER参数在RAC环境下非常重要,是服务器实现负载均衡的一个工具。...在服务器端的连接中,Oracle NET通过remote_listener确定当前RAC中的远程监听和实例,以便分发连接。
♣ 题目部分 在Oracle中,简述Oracle中的游标。 ♣ 答案部分 在介绍游标之前先介绍一下Oracle数据库中库缓存(Library Cache)的作用及其组成结构。...当同样的SQL语句和PL/SQL语句再次被执行的时候就可以直接利用已经缓存在库缓存中的那些相关对象而无须再次从头开始解析,这样就提高了这些SQL语句和PL/SQL语句在重复执行时的执行效率。...库缓存(Library Cache)在SGA中的位置如下图所示: ?...当Oracle要执行目标SQL“select * from lhr.emp”时,首先会对该SQL的SQL文本进行哈希运算,然后根据得到的哈希值找到相关的Hash Bucket,在Hash Bucket中遍历对应的库缓存对象句柄链表...各个Data Heap之间是独立的,没有关联关系,Oracle会在Heap 0的属性“Data Blocks Pointer”中存储指向这些Data Heap的指针,这样Oracle通过访问Heap 0
♣ 题目部分 在Oracle中,SQL_TRACE是什么?诊断事件是什么?...♣ 答案部分 (一)SQL_TRACE SQL_TRACE是Oracle提供的用于进行SQL跟踪的手段,是强有力的辅助诊断工具。在日常的数据库问题诊断和解决中,SQL_TRACE是非常常用的方法。...参数文件中设置事件,这样数据库在OPEN后,将影响到所有的会话。...,事件号可以是Oracle错误号(出现相应错误时跟踪指定的事件)或Oralce内部事件号,内部事件号在10000到10999之间,不能与immediate关键字同用。...如果事件是在pfile文件中设置的,那么可以用“SHOW PARAMETER EVENT”来查看。
领取专属 10元无门槛券
手把手带您无忧上云