8i | 9i | 10g | 11g | 12c | 13c | 18c | 19c | 21c | 23ai | Misc | PL/SQL | SQL | RAC | WebLogic | Linux
Oracle 23ai Articles
- Oracle Database 23ai : Miscellaneous Articles
- Oracle Database 23ai: Installations
- What Happened to Oracle Database 23c?
Oracle Database 23ai : Miscellaneous Articles
Oracle 23ai will be the next long term release of the database. In preparation, aim to get all your current databases upgraded to Oracle 19c to ease migration to 23ai.
Aggregation over INTERVAL Datatypes in Oracle Database 23ai - Oracle 23ai allows us to use the SUM and AVG aggregate and analytic functions with INTERVAL datatypes for the first time.
AI Vector Search in Oracle Database 23ai - This article provides a simple example of using the AI Vector Search feature in Oracle database 23ai.
Annotations in Oracle Database 23ai - This article describes the use of annotations to document our database objects in Oracle database 23ai.
ARGUMENT Command in SQL*Plus 23ai and SQLcl 22.4 - The ARGUMENT command in SQL*Plus 23ai and SQLcl 22.4 allows us to manage arguments passed to a script. This includes the prompt or default value if an argument is missing, and whether the user input from a prompt should he echoed to the screen.
Auditing Enhancements in Oracle Database 23ai - This post describes some of the auditing enhancements in Oracle database 23ai.
Automatic PL/SQL to SQL Transpiler in Oracle Database 23ai - The automatic SQL transpiler in Oracle 23ai allows some functions to be converted into SQL expressions to reduce the overhead of function calls in SQL.
Bigfile Tablespace Defaults in Oracle Database 23ai - Bigfile tablespaces were introduced in Oracle 10g. In Oracle database 23ai bigfile tablespaces are the default.
Bigfile Tablespace Shrink in Oracle Database 23ai - From Oracle database 23ai onward we can use the DBMS_SPACE package to shrink a bigfile tablespace to reclaim unused space.
Blockchain Table Enhancements in Oracle Database 23ai - Blockchain tables were first introduced in Oracle 21c, and backported to Oracle 19c. This article demonstrates the enhancements to blockchain tables in Oracle 23ai.
Boolean Data Type in Oracle Database 23ai - Oracle database 23ai introduced the boolean data type in SQL.
CASE Statement and CASE Expression Enhancements in Oracle Database 23ai - In Oracle database 23ai the simple CASE statement and expression are more flexible, allowing dangling predicates and multiple choices in a single WHEN clause.
CEIL and FLOOR Support DATE, TIMESTAMP, and INTERVAL Data Types in Oracle Database 23ai - In Oracle database 23ai the CEIL and FLOOR functions support the DATE, TIMESTAMP and INTERVAL data types.
Database Resident Connection Pool (DRCP) Enhancements in Oracle Database 23ai - Oracle database 23ai enhanced the Database Resident Connection Pool (DRCP) functionality to include multiple named pools and implicit connection pooling.
DB_DEVELOPER_ROLE Role in Oracle Database 23ai - Oracle database 23ai introduced a new DB_DEVELOPER_ROLE role, to provide the basic roles and privileges Oracle believe are necessary for a database developer.
DBMS_HCHECK in Oracle Database 23ai - In Oracle 23ai the DBMS_HCHECK package allows us to check for known data dictionary problems in the database.
DEFAULT ON NULL FOR INSERT AND UPDATE in Oracle Database 23ai - In Oracle 23ai we can define a column as DEFAULT ON NULL FOR INSERT AND UPDATE. This replaces explicit null values with the default value in update statements.
Direct Joins for UPDATE and DELETE Statements in Oracle Database 23ai - From Oracle database 23ai onward we are allowed to use direct joins to tables to drive UPDATE and DELETE statements.
DML RETURNING Clause Enhancements in Oracle Database 23ai - This article demonstrates the enhancements to the DML RETURNING clause introduced in Oracle database 23ai.
Domains in Oracle Database 23ai - This article demonstrates the use of Domains in Oracle database 23ai.
EMPTY STRING ON NULL for JSON Generation in Oracle Database 23ai - Oracle database 23ai has introduced the ability to convert nulls to empty strings during JSON generation.
Enhanced Partitioning Metadata in Oracle Database 23ai - Oracle database 23ai makes it easier to display the high value of partitions using two new columns in the ALL_TAB_PARTITIONS view.
FUZZY_MATCH and PHONIC_ENCODE Data Quality Operators in Oracle Database 23ai - Oracle database 23ai introduced the FUZZY_MATCH and PHONIC_ENCODE data quality operators to perform fuzzy string matching.
GROUP BY and HAVING Clauses Using Column Aliases in Oracle Database 23ai - From Oracle 23ai onward we can use the column alias in GROUP BY and HAVING clauses, or the column position in the GROUP BY clause.
Hybrid Partitioned Table Enhancements in Oracle Database 23ai - This article demonstrates hybrid partitioned tables with interval and auto-list partitioning in Oracle Database 23ai.
Hybrid Read-Only Mode for PDBs in Oracle Database 23ai - Oracle 23ai allows us to open PDBs in hybrid read-only mode. This allows common users to work in read-write mode, while local users and common application users are restricted to read-only mode.
IF [NOT] EXISTS DDL Clause in Oracle Database 23ai - Prevent errors during object creation and removal using the IF [NOT] EXISTS DDL clause in Oracle Database 23ai.
Immutable Table Enhancements in Oracle Database 23ai - Immutable tables were introduced to Oracle 21.3 and 19.11 at the same time, so it could be considered a 19c and 21c new feature. This article demonstrates the enhancements to immutable tables in Oracle 23ai.
JSON_ARRAY Using Subqueries in Oracle Database 23ai - From Oracle database 23ai onward the JSON_ARRAY function can accept a subquery as input, which brings it in line with the current SQL/JSON standard.
JSON_BEHAVIOR Parameter in Oracle Database 23ai - By default many JSON functions return null if they encounter a runtime error. Oracle database 23ai introduced the JSON_BEHAVIOR parameter to allow us to alter this default behaviour for our session.
JSON Data Type Constructor Enhancements in Oracle Database 23ai - The JSON data type constructor can now accept collections, object types and record types as input.
JSON-Relational Duality Views in Oracle Database 23ai - JSON-relational duality views expose our relational data as JSON documents, allowing both query and DML operations to be performed using conventional SQL or directly using JSON.
JSON Schema in Oracle Database 23ai - In Oracle database 23ai a JSON Schema can validate the structure and contents of JSON documents in your database.
JSON_SERIALIZE : ORDERED Keyword in Oracle Database 23ai - In Oracle 23ai the ORDERED keyword has been added to the JSON_SERIALIZE function. When present, the members are serialized in ascending alphabetical order by field name.
JSON Support Enhancements in Oracle Database 23ai - Oracle 23ai includes several enhancements to the JSON functionality in the database. This post acts as a links page to separate articles on each feature.
JSON_TRANSFORM Enhancements in Oracle Database 23ai - In Oracle 23ai the JSON_TRANSFORM function has lots of new operations, conditional control and richer path support.
JSON_VALUE Function Enhancements in Oracle Database 23ai - In Oracle database 23ai the RETURNING clause of the JSON_VALUE function has been enhanced allowing it to convert JSON data to user-defined types.
Loading JSON Data using External Tables in Oracle Database 23ai - In Oracle database 23ai loading JSON data using external tables got much simpler.
Loading SODA Collections with SQL*Loader in Oracle Database 23ai - In Oracle 23ai we can use SQL*Loader to load JSON data into a Simple Oracle Document Access (SODA) collection.
Lock-Free Reservations to Prevent Blocking Sessions in Oracle Database 23ai - In Oracle 23ai we can use Lock-Free Reservations to reduce the incidents of blocking sessions for frequently updated numeric column values.
Logical Partition Change Tracking (LPCT) for Materialized Views in Oracle Database 23ai - In Oracle database 23ai Logical Partition Change Tracking (LPCT) allows materialized view staleness to be tracked at the level of a logical partition.
Materialized View Concurrent Refreshes in Oracle Database 23ai - In Oracle 23ai materialized view refreshes can be performed concurrently for on-commit fast refreshes by adding the ENABLE CONCURRENT REFRESH clause.
Materialized View Enhancements in Oracle Database 23ai - This post introduces some of the materialized view enhancements in Oracle database 23ai.
Materialized View Support for ANSI Joins in Oracle Database 23ai - In Oracle 23ai materialized views support query rewrites for SQL statements using ANSI or Oracle style joins.
MAX_COLUMNS : Increase the Maximum Number of Columns for a Table (Wide Tables) in Oracle Database 23ai - Oracle 23ai introduced the MAX_COLUMNS initialization parameter, which allows us to have up to 4096 columns in a table.
Migrating Text-Based JSON to JSON Data Type : Pre-Migration Check in Oracle Database 23ai - In Oracle 23ai the JSON_TYPE_CONVERTIBLE_CHECK procedure has been added to the DBMS_JSON package to allow pre-migration checks to be performed on text-based JSON columns.
Multilingual Engine (MLE) for JavaScript in Oracle Database 23ai - Oracle 23ai extends the multilingual engine (MLE) with the addition of persistent MLE modules and call specs that allow modules to be called from SQL and PL/SQL.
Oracle REST Data Services (ORDS) : AutoREST of JSON-Relational Duality Views - This article gives an overview of the AutoREST functionality of Oracle REST Data Services (ORDS) against JSON-relational duality views in Oracle 23ai.
Oracle SQL and PL/SQL Enhancements in Oracle Database 23ai - This page provides links to all the separate articles on SQL and PL/SQL enhancements in Oracle Database 23ai.
Precheck Constraints using JSON Schema in Oracle Database 23ai - In Oracle database 23ai we can use the PRECHECK keyword to mark check constraints as being validated externally by an application.
Predicates for JSON_QUERY and JSON_VALUE in Oracle Database 23ai - In Oracle database 23ai the JSON_QUERY and JSON_VALUE functions can include multiple predicates in a single JSON path expression, and use the PASSING clause to support variables.
Read-Only PDB Users in Oracle Database 23ai - Oracle database 23ai allows us to make PDB users read-only, which makes a connected session act like the database is opened in read-only mode, preventing the session from performing write operations.
Removal of Touch-Once Restriction after Parallel DML (Unrestricted Direct Loads) in Oracle Database 23ai - Oracle database 23ai makes parallel DML more flexible by removing the touch-once restriction after parallel DML. This is also know as unrestricted direct loads.
Rename LOB Segments in Oracle Database 23ai - The article demonstrates how to rename a LOB segment in Oracle 23ai.
Schema Privileges in Oracle Database 23ai - Schema privileges allow us to simplify grants where a user or role needs privileges on all objects in a schema.
SELECT Without FROM Clause in Oracle Database 23ai - From Oracle 23ai onward we can use a SELECT without a FROM clause in some circumstances.
SQL Firewall in Oracle Database 23ai - The SQL Firewall allows us to detect, block and log unexpected SQL and session contexts in an Oracle 23ai database, giving us greater control to prevent unusual activity.
SQL Property Graphs and SQL/PGQ in Oracle Database 23ai - Oracle have had a Graph Server and Client product for some time, but in Oracle database 23ai some of the property graph functionality has been built directly into the database.
SQL*Plus New Features in Oracle Database 23ai - This article describes the new features of SQL*Plus in Oracle Database 23ai.
Staging Tables in Oracle Database 23ai - Oracle database 23ai introduces the FOR STAGING clause in the CREATE TABLE command to create a variation of heap tables, which have optimal configuration for fast data ingestion.
Table Values Constructor in Oracle Database 23ai - The table values constructor allows us to define multiple rows using a single constructor for use in SQL statements.
TLS and Wallet Enhancements in Oracle Database 23ai - Oracle 23ai includes several enhancements to Transport Layer Security (TLS) and wallets, simplifying configuration, and making the database more secure.
Transport Layer Security (TLS) Connections without a Client Wallet in Oracle Database 23ai - In previous releases making HTTPS callouts from the database required the use of a client wallet. From Oracle database 23ai onward we can use the operating system certificate store instead.
XML, JSON and Oracle Text Search Index Enhancements in Oracle Database 23ai - In Oracle 23ai the CREATE SEARCH INDEX statement allows us to create search indexes on XML, JSON and text data, making the syntax consistent between them.
Oracle Database 23ai : Installations
Oracle Database 23ai Free RPM Installation On Oracle Linux 8 (OL8) - This article describes the RPM installation of Oracle Database 23ai Free 64-bit on Oracle Linux 8 (OL8) 64-bit.
Oracle Database 23ai Free RPM Installation On Oracle Linux 9 (OL9) - This article describes the RPM installation of Oracle Database 23ai Free 64-bit on Oracle Linux 9 (OL9) 64-bit.
What Happened to Oracle Database 23c?
Oracle Database 23c was rebranded to Oracle Database 23ai. Many of the articles on this page were written against Oracle Database 23c, which is why they still have that title and a URL that reflects that name. Over time these articles will be amended to reflect the change to 23ai, and all links will be redirected to the new version of the article.