数据库管理-第六十五期 Oracle 23c新特性(20230411)

数据库管理 2023-04-11

  • 第六十五期 Oracle 23c新特性
    • 1 免费版23c目录结构
    • 2 新特性
    • 总结

第六十五期 Oracle 23c新特性

上一期装了免费版23c,这一期根据安装的数据库,对Oracle 23c的部分新特性进行实验展示。

1 免费版23c目录结构

通过RPM包安装的免费版23c,$ORACLE_HOME即软件家目录为/opt/oracle/product/23c/dbhomeFree
因此按照一般标准把配置文件改了改,并重新创建了数据库实例。
数据库管理-第六十五期 Oracle 23c新特性(20230411)_第1张图片
同时ORACLE用户的环境变量也改为以下配置:

export ORACLE_HOME=/opt/oracle/product/23c/dbhomeFree
export ORACLE_SID=FREE
export PATH=/opt/oracle/product/23c/dbhomeFree/bin:$PATH

新特性的部分操作将通过这个环境进行演示。freepdb1安装了sample schema测试数据。
下面部分内容源自“机翻”。

2 新特性

【https://docs.oracle.com/en/database/oracle/oracle-database/23/nfcoa/introduction.html】

  • JSON关系二元性
    现在数数据可以作为JSON文档或关系表透明地进行访问和更新。
    开发人员受益于这两者的优势,它们比对象关系映射(ORM)更简单、更强大。

  • 可操作属性图
    开发人员现在可以直接在Oracle数据库中的操作数据构建实时图分析应用程序,利用其行业领先的安全性、高可用性和性能能力。

  • 微服务支持

  • 无锁列值保留
    无锁定列值保留允许应用程序在不锁定行的情况下保留部分列值;例如,保留银行账户余额的部分或保留库存中的项目,而不锁定银行账户或项目中的所有其他操作。

  • OKafka
    Kafka应用可以通过最小的代码改在直接在Oracle数据库运行高性能的事务事件队列(TxEventQ)。

  • JavaScript存储过程
    现在可以创建使用JavaScript的存储过程。这个功能还允许使用大量的JavaScript库。

  • SQL Domains
    SQL Domains允许开发人员以集中式和轻量级的方式声明数据(列)的预期用途。例如,声明一个列包含一个电子邮件、URL、密码、货币等。应用程序可以使用SQL域来自动生成代码或验证值。

  • 数据类型及SQL增强
    – 布尔类型数据支持
    数据库管理-第六十五期 Oracle 23c新特性(20230411)_第2张图片
    数据库管理-第六十五期 Oracle 23c新特性(20230411)_第3张图片

    – UPDATE和DELETE语句的直接JION
    – Unicode 15.0支持
    – 无需FROM子句的SELECT
    数据库管理-第六十五期 Oracle 23c新特性(20230411)_第4张图片
    这种情况可以省去很多from daul。
    – 通过列别名或者位置进行GROUP BY
    数据库管理-第六十五期 Oracle 23c新特性(20230411)_第5张图片
    可以简化很多语句书写。

  • 每个表支持4096列

  • SCHEMA级别权限
    现在可以在SCHEMA级别上授予系统权限。此特性简化了特权管理过程,因此,使数据库的安全更加容易。
    数据库管理-第六十五期 Oracle 23c新特性(20230411)_第6张图片
    数据库管理-第六十五期 Oracle 23c新特性(20230411)_第7张图片

  • Developer角色
    新角色允许管理员快速地为开发人员分配他们为Oracle数据库设计、构建、DEBUG和部署应用程序所需的权限。

grant DB_DEVELOPER_ROLE to USER.
  • DDL的IF EXISTS判断
    在DDL中,支持通过 IF [NOT] EXISTS 判断,从而规避执行过程中的错误、异常和中断。
    数据库管理-第六十五期 Oracle 23c新特性(20230411)_第8张图片
    并不会对原表造成影响。

总结

Oracle 23c还有更多的新特性以及增强特性,在往后的会不断去摸索。
老规矩,知道写了些啥。

你可能感兴趣的:(Oracle,数据库,oracle)