2022年oracle数据库面试题
2022年oracle数据库面试题精选
Oracle公司针对职业教育市场在全球推广的项目,其以低廉的本钱给这部分人供应Oracle技术培训,经过系统化的实训,让这部分人能够快速把握Oracle最新的核心技术,并能胜任企业大型数据库管理、维护、开发工作。下面是我收集的oracle数据库面试题,期望大家认真阅读!
1. Oracle跟SQL Server 2022的区分?
宏观上:
1). 最大的区分在于平台,oracle可以运行在不同的平台上,sql
server只能运行在windows平台上,由于windows平台的稳定性和安全性影响了sql server的稳定性和安全性
2). oracle使用的脚本语言为PL-SQL,而sql server使用的脚本为T-SQL
微观上:从数据类型,数据库的结构等等回答
2. 如何使用Oracle的游标?
1). oracle中的游标分为显示游标和隐式游标
2). 显示游标是用is指令定义的游标,它可以对查询语句(select)返回的多条记录进行处理;隐式游标是在执行插入(insert)、删除(delete)、修改(update)和返回单条记录的查询(select)语句时由PL/SQL自动定义的。
3). 显式游标的操作:打开游标、操作游标、关闭游标;PL/SQL 隐式地打开SQL游标,并在它内部处理SQL语句,然后关闭它
3. Oracle中function和procedure的区分?
1). 可以理解函数是存储过程的一种
2). 函数可以没有参数,但是确定需要一个返回值,存储过程可以没有参数,不需要返回值
oracle游标的使用3). 函数return返回值没有返回参数模式,存储过程通过out参数返回值, 假如需要返回多个参数则建议使用存储过程
4). 在sql数据操纵语句中只能调用函数而不能调用存储过程
4. Oracle的导入导出有几种方式,有何区分?
1). 使用oracle工具 exp/imp
2). 使用plsql相关工具
方法1. 导入/导出的是二进制的数据, 2.plsql导入/导出的是sql语句的文本文件
5. Oracle中有哪几种文件?
数据文件(一般后缀为.dbf或者.ora),日志文件(后缀名.log),把握文件(后缀名为.ctl)
6. 怎样优化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). 合理使用事务,合理设置事务隔离性
数据库的数据操作比较消耗数据库资源的,尽量使用批量处理,以降低事务操作次数
7. Oracle中字符串用什么符号链接?
Oracle中使用 || 这个符号连接字符串如 abc || d
8. Oracle分区是怎样优化数据库的?
Oracle的分区可以分为:列表分区、范围分区、散列分区、复合分区。
1). 增加可用性:假如表的一个分区由于系统故障而不能使用,表的其余好的分区仍可以使用;
2). 削减关闭时间:假如系统故障只影响表的一部份分区,那么只有这部份分区需要修复,可能比整个大表修复花的时间更少;
3). 维护轻松:假如需要得建表,独产管理每个公区比管理单个大表要轻松得多;
4). 均衡I/O:可以把表的不同分区支配到不同的磁盘来平衡I/O 改善性能;
5). 改善性能:对大表的查询、增加、修改等操作可以分解到表的不同分区来并行执行,可使运行速度更快 6). 分区对用户透亮,最终用户感觉不到分区的存在。
9. Oracle是怎样分页的?
Oracle中使用rownum来进行分页, 这个是效率最好的分页方法,hibernate也是使用rownum来进行oralce分页的
select * from
( select rownum r,a from tabName where rownum = 20 )
where r 10
10. Oralce怎样存储文件,能够存储哪些文件?
Oracle 能存储 clob、nclob、 blob、 bfile
Clob 可变长度的字符型数据,也就是其他数据库中提到的文本型数据类型
Nclob 可变字符类型的数据,不过其存储的是Unicode字符集的字符数据
Blob 可变长度的二进制数据
Bfile 数据库外面存储的可变二进制数据
11. Oracle中使用了索引的列,对该列进行where条件查询、分组、排序、使用聚集函数,哪些用到了索引?
均会使用索引,值得留意的是复合索引(如在列A和列B上建立的索引)可能会有不怜悯况
12. 数据库怎样实现每隔30分钟备份一次?
通过操作系统的定时任务调用脚本导出数据库
13. Oracle中where条件查询和排序的性能比较?
Order by使用索引的条件极为严格,只有满足如下状况才可以使用索引,
1). order by中的列必需包含相同的索引并且索引顺序和排序顺序一致
2). 不能有null值的列
所以排序的性能往往并不高,所以建议尽量避开order by 14. 解释冷备份和热备份的不同点以及各自的优点?
冷备份发生在数据库已经正常关闭的状况下,将关键性文件拷贝到另外位置的一种说法
热备份是在数据库运行的状况下,接受归档方式备份数据的方法冷备的优缺点:
1).是特殊快速的备份方法(只需拷贝文件)
2).简洁归档(简洁拷贝即可)
3).简洁恢复到某个时间点上(只需将文件再拷贝回去)
4).能与归档方法相结合,作数据库"最新状态'的恢复。
5).低度维护,高度安全。
冷备份缺乏:
1).单独使用时,只能供应到"某一时间点上'的恢复。
2).在实施备份的全过程中,数据库必需要作备份而不能作其它工作。也就是说,在冷备份过程中,数据库必需是关闭状态。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论