Oracle 19c十大新特性
eygle对Oracle 18c、19c和20c十大新特性做了介绍,
https://www.eygle.com/archives/2019/10/oracle_database_20c_new_features.html
历史文章,
这次我们了解Oracle 19c,Oracle Database 19c的10大新特性一览。
1.Data Guard 备库DML自动重定向
在使用ADG作为备库进行读写分离部署时,可能因为应用的原因,会有偶然的DML操作发送到备库上,在19c中,Oracle支持自动重定向备库DML,具体执行步骤为:
更新会自动重定向到主库;
主库执行更新、产生和发送Redo日志到备库;
在Redo备库应用后,ADG会话会透明的看到更新信息的落地实施;
这一特性可以通过在系统级或者会话级设置参数ADG_REDIRECT_DML参数启用,通过这种方式,ADG会话的ACID一致性得以保持,同时透明的支持『多数读,偶尔更新』应用的自然读写分离配置。
这个特性的引入,将进一步的增加ADG的灵活性,帮助用户将备库应用的更加充分,
2.Oracle Sharding 特性的多表家族支持
在Oracle Sharding特性中,被分片的表称为Sharded table,这些sharded table的集合称为表家族(Table Family),表家族之中的表具备父-子关系,一个表家族中没有任何父表的表叫做根表(root table),每个表家族中只能有一个根表。表家族中的所有Sharded table都按照相同的sharding key(主键)来分片。
在12.2,在一个SDB中只支持一个表家族,在19c中,SDB中允许存在多个表家族,每个通过不同的Sharding Key进行分片,这是Sharding特性的一个重要增强,有了Multiple Table Families的支持,Sharding才可能找到更多的应用场景,
3.透明的应用连续性支持增强
在Oracle RAC集群中,支持对于查询的自动切换,当一个节点失效,转移到另外一个节点,在19c中,Oracle持续改进和增强了连续性保持,数据库会自动记录会话状态,捕获用于重演的信息,以便在切换时,在新节点自动恢复事务,使DML事务同样可以获得连续性支持:
在事务提交后自动禁用状态捕获,因为提交成功的事务将不再需要在会话级恢复;
在事务开始时,自动重新启用状态跟踪;
4.自动化索引创建和实施
对于关系型数据库来说,索引是使得查询加速的重要手段,而如何设计和创建有效的索引,长期以来是一项复杂的任务。
在Oracle 19c中,自动化索引创建和实施技术被引入进来,Oracle通过模拟人工索引的思路,建立了内置的专家系统。
数据库内置的算法将会通过捕获、识别、验证、决策、在线验证、监控的全流程管控索引自动化的过程。
这一特性将会自动帮助用户创建有效的索引,并通过提前验证确保其性能和有效性,并且在实施之后进行监控,这一特效将极大缓解数据库索引维护工作。
自动化还将删除由新创建的索引(逻辑合并)废弃的索引,并删除自动创建但长时间未使用的索引,
5.多实例并行重做日志应用增强
在Oracle Data Guard环境中,备库的日志应用速度一直是一个重要挑战,如果备库不能够及时跟上主库的步调,则可能影响备库的使用。
自Oracle 12.2版本开始,支持多实例并行应用,这极大加快了恢复进度,在18c中,开始支持In-Memory列式存储,在19c中,并行应用开始支持In-Memory列式存储,
6.Oracle的混合分区表支持
在19c中,Oracle增强了分区特性,可以将外部对象存储上的文件,以外部表的方式链接到分区中,形成混合分区表,借助这个特性,Oracle将数据库内外整合打通,冷数据可以剥离到外部存储,热数据在数据库中在线存储。
这个特性借助了外部表的特性实现,以下是一个示例:
CREATE TABLE orders ( order_idnumber, order_dateDATE, … ) EXTERNAL PARTITION ATTRIBUTES ( TYPE oracle_loaderDEFAULTDIRECTORY data_dir ACCESS PARAMETERS (..) REJECT LIMIT unlimited) PARTITION BY RANGE(order_date) ( partition q1_2015 values less than('2014-10-01’) EXTERNAL LOCATION ('order_q1_2015.csv’), partition q2_2015 values less than ('2015-01-01’), partition q3_2015 values less than ('2015-04-01’), partition q4_2015 values less than ('2015-07-01’));
7.在线维护操作增强
在不同版本中,Oracle持续增强在线维护操作,例如在12.2开始支持的Online Move、在线修改普通表为分区表等特性。
在19c中,持续增强了智能的、细粒度的游标失效控制,将DDL操作对于游标失效的影响降至最低,例如,在19c中,comment on table的操作,将不会引起游标的失效。
针对分区维护的操作,例如Truncate分区等,Oracle将进行细粒度的控制,和DDL操作无关的SQL将不受DDL失效影响,
8.自动的统计信息管理
随着表数据的变化,优化器表数据统计数据将近实时刷新,以防止次优执行计划,
统计的在线维护内置于直接路径加载操作中
当数据显着变化时运行自动统计信息收集作业,例如。,自上次收集统计信息以来,表中超过10%的行被添加/更改
第一个看到需要重新编译SQL游标的会话(例如,由于新的优化器统计信息)执行重新编译
其他会话继续使用旧的SQL游标,直到编译完成
避免因重新编译而导致大量会话停顿
9.自动化的SQL执行计划管理
在19c中,数据库缺省的就会启用对于所有可重用SQL的执行计划捕获(当然SYS系统Schema的SQL除外),然后进行自动的执行计划评估,评估可以针对AWR中的TOP SQL、SGA、STS中的SQL进行。
如果被评估的执行计划优于当前执行计划(一般是要有效率 50%以上的提升),会被加入到执行计划基线库中,作为后续的执行选择,而不佳的执行计划则会被标记为不可接受。
有了这个特性,SQL执行计划的稳定性将更进一步,
10.SQL功能的增强
在19c中,SQL 功能获得了进一步的增强,这其中包括对于COUNT DISTINCT的进一步优化,在12c中引入的近似 Distinct操作已经可以为特定SQL带来极大性能提升,现在基于位图的COUNT DISTINCT操作继续为查询加速。
除此之外,LISTAGG 增加了DISTINCT关键字,用于对操作数据的排重。
ANY_VALUE提供了从数据组中获得随机值的能力,如果你以前喜欢用Max/Min实现类似的功能,新功能将显著带来效率的提升。ANY_VALUE函数在MySQL早已存在,现在应该是Oracle借鉴和参考了MySQL的函数做出的增强,
在SQL方面,Oracle的能力超乎想象。