Java工程师必知词汇:Oracle

Oracle是甲骨文公司的一款关系型数据库管理系统,当前仍在数据库市场上占有主要份额。甲骨文公司全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。现时首席执行官为Safra Catz, CTO为公司创办人劳伦斯.埃里森。直到2013年为止,甲骨文是继微软后,全球收入第二多的软件公司。

Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的 适应高吞吐量的数据库解决方案。

一个Oracle数据库系统是以一个由字母和数字组成的系统标识符(SID, Site ID)来做唯一性的区别,包含了至少一个应用程序的实例和数据存储设备。一个实例(instance)是由一个实例数字(或是一个引导ID:SYS.V_$DATABASE.ACTIVATION#)表示包含了一个操作系统程序的集合和与存储设备进行交谈的内部结构。典型的程序有PMON(the process monitor程序监看器)和SMON(the system monitor系统监看器)。

Oracle数据库重要组成部分SGA(System Global Area系统全局领域)服务器端内存结构。SGA保存了缓存信息,比如数据缓冲区,SQL命令,和用户信息。在存储之外,数据库由保存了数据变更历史的在线恢复日志。进程可以把在线的恢复日志转换成存档的日志(离线恢复日志),给数据恢复和再生提供了基础。

如果Oracle数据库管理员实现了Oracle RAC(Real Application Clusters真正应用集群),那么在不同的服务器上的多个实例,隶属于一个*磁盘阵列。这个方案提供了一些优点,比如更高的效率、扩展性和冗余。然而,这样会导致系统更复杂,因此许多站点并不使用RAC。在10g版本中,网格计算引进了共享资源,这样一个实例可以使用(例如)网格中另一个节点的CPU资源。

Oracle数据库管理系统可以保存并运行自己的存储程序和函数。PL-SQL(Oracle公司的专有的SQL扩展语言),或面向对象语言Java可以调用那些代码对象或者编写这些代码。

Oracle关系型数据库管理系统从逻辑上把数据保存在表空间内,在物理上以数据文件的形式存储。表空间可以包含多种类型的内存区块,例如数据区块(Data Segment)、索引区块(Index Segment)等等。区块相应的由一个或多个扩展(extent)组成。扩展由相连的数据区块组成。数据区块是数据存储的基本单元。

|参考资料|

[1] 阿里云开发者社区-学习中心-java学习路线-数据库开发
[2] JDBC 2.甲骨文历史回顾 2004年4月 ezone杂志
[3] 陈晓莉. 甲骨文准备以12亿美元买下云端施工专案管理服务商Aconex. IT之家. 2017-12-18 [2018-12-04].

上一篇:Java工程师必知词汇:单例/多例设计模式


下一篇:Java工程师必知词汇:数据库