龙空技术网

oracle常见面试题总结(上)

程序员VenusKong 555

前言:

现在我们对“oracle查询某个表每次都卡顿”大致比较讲究,我们都需要学习一些“oracle查询某个表每次都卡顿”的相关知识。那么小编也在网摘上收集了一些关于“oracle查询某个表每次都卡顿””的相关知识,希望小伙伴们能喜欢,同学们快快来学习一下吧!

001 数据库分页查询

  select * from (

select t.*,rownum from table1 t where condition )

where rownum>(pangeNow-1)*pageSize and rownum<=(pageNow)*pageSize

002 事务概念

  答案:事务是这样一种机制,它确保多个SQL语句被当作单个工作单元来处理。事务具有以下的作用:

一致性:同时进行的查询和更新彼此不会发生冲突,其他用户不会看到发生了变化但尚未提交的数据。

可恢复性:一旦系统故障,数据库会自动地完全恢复未完成的事务。

003 触发器的作用,什么时候用触发器,创建触发器的步骤,触发器里是否可以有commit, 为什么?

  答案:触发器是可以由事件来启动运行的,存在于数据库服务器中的一个过程。他的作用:可以实现一般的约束无法完成的复杂约束,从而实现更为复杂的完整性要求。使用触发器并不存在严格的限定,只要用户想在无人工参与的情况下完成一般的定义约束不可以完成的约束,来保证数据库完整性,那么就可以使用触发器。

由于触发器主要是用来保证数据库的完整性的,所以要创建一个触发器,首先要明确该触发器应该属于那一种(DML,INSTEAD OF,SYSTEM)因为他们各有个的用途;其次就是要确定触发器被触发以后所设计到的数据。 触发器中不可以使用COMMIT。

004 关系数据库系统与文件数据库系统的区别在那里?关系数据库系统一般适用那些方面?

  答案: 关系数据库系统文件系统的区别在于:

首先,关系性数据库的整体数据是结构化的,采用关系数据模型来描述,这是它与文件系统的根本区别。(数据模型包括:数据结构,数据操作以及完整性约束条件)

其次,关系数据库系统的共享性高,冗余低可以面向整个系统,而文件系统则具有应用范围的局限性,不易扩展。

第三,关系数据库系统采用两级映射机制保证了数据的高独立性,从而使得程序的编写和数据都存在很高的独立性。这方面是文件系统无法达到的,它只能针对于某一个具体的应用。(两级映射:保证逻辑独立性的外模式/模式映射和保证物理独立性的内模式/模式映射。外模式:用户模式,是数据库用户的局部数据的逻辑结构特征的描述。模式:数据库全体数据的逻辑结构特征的描述。内模式:也就是数据最终的物理存储结构的描述。)

第四,就是关系性数据库系统由统一的DBMS进行管理,从而为数据提供了如安全性保护,并发控制,完整性检查和数据库恢复服务。

005 触发器的概念,存储过程的概念.

  答案: 触发器: 是存储在数据库中的过程,当表被修改(增、删、改)时它隐式地被激发。 存储过程:是数据库语言SQL的集合,同样也存储在数据库中,但是他是由其他应用程序来启动运行或者也可以直接运行。

006 什么是事务一致性 ? 选择熟悉的数据库实现一个事务处理,如信用卡提款. 答案:

  事务的一致性:是事务原子性的体现,事务所对应的数据库操作要么成功要么失败没有第三种情况。事务不管是提交成功与否都不能影响数据库数据的一致性状态。

事务:用户定义的一个数据库操作序列,这些操作要么全部成功完成要么全部不做,是一个不可分割的整体。定义事务的SQL语句有:BEGIN TRANSACTION,COMMIT,ROLLBACK。

事务的原子性:就是事务所包含的数据库操作要么都做,要么都不做.

事务的隔离性:事务对数据的操作不能够受到其他事务的影响。

事务的持续性:也就是说事务对数据的影响是永久的。

对信用卡提款这一事务而言就是要保证’提取到现金’和’卡帐号余额’的修改要同时成功或失败.

BEGIN TRANSACTION

读取A的帐户余额BALANCE

BALANCE=BALANCE-AMOUNT转帐金额

IF(BALANCE<0)

THEN ROLLBACK

ELSE BEGIN

将A的新余额写回

读取B的帐户余额BALANCEB

BALANCEB=BALANCEB+AMOUNT转帐金额

将B的新余额写回

COMMIT

END IF

END

007 实现索引的方式? 索引的原理? 索引的代价? 索引的类型?

  答案: 实现索引的方式有两种:针对一张表的某些字段创建具体的索引,如对oracle: create index 索引名称 on 表名(字段名);在创建表时为字段建立主键约束或者唯一约束,系统将自动为其建立索引。

索引的原理:根据建立索引的字段建立索引表,存放字段值以及对应记录的物理地址,从而在搜索的时候根据字段值搜索索引表的到物理地址直接访问记录。

引入索引虽然提高了查询速度,但本身占用一定的系统存储容量和系统处理时间,需要根据实际情况进行具体的分析.

(oracle)索引的类型有:B树索引,位图索引,函数索引等。

008 view 的概念 ? 何时应用?

答案: view 是对表级数据的多角度的透视,适用于对查询安全性、灵活性有一定要求的环境.

009 使用存储过程访问数据库比直接用SQL语句访问有哪些优点?

  答案:存储过程是预编译过的,执行时无须编译,执行速度更快;存储过程封装了一批SQL语句,便于维护数据的完整性与一致性;可以实现代码的复用。

010 Oracle中回滚的概念?回滚段有什么作用。

  回滚就是在事务提交之前将数据库数据恢复到事务修改之前数据库数据状态。

回滚段就是为回滚提供依据,记录的是事务操作数据库之前的数据或者对应于以前操作的操作,这个内容要根据以前的操作而定。比如说以前事务操作如果是UPDATE那么回滚段则存储UPDATE以前的数据,如果事务是DELETE操作那么存储的则是与之相对应的INSERT操作语句,相反如果事务操作是INSERT那么记录相应的则是DELETE操作了。

标签: #oracle查询某个表每次都卡顿 #oracle唯一索引冲突 #oracle函数面试