Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents
minLevel1
maxLevel6
outlinefalse
typelist
printablefalse

Overview

The JDBC driver for Oracle in the Oracle Snap Pack is upgraded from OJDBC6 JAR JAR (11v11.2.0.4 version) to OJDBC10 JAR (19v19.20.0.0 version)) in the stable distribution in the November 2023 release. As part of this upgrade, the 19.20.0.0 JDBC driver is bundled with the Oracle Snap Pack as the default JDBC driver.

FAQ for the Oracle JDBC Driver Upgrade

What is happening?

The Oracle JDBC Driver is upgraded from OJDBC6 JAR (11.2.0.4 version) to the OJDBC10 JAR (19.20.0.0 version). The OJDBC10 JAR is bundled with the Oracle Snap Pack as the default driver.

Why are we upgrading the Oracle driver?

The decision to upgrade the Oracle JDBC driver from version 11.2.0.4 to 19.20.0.0 is made to improve security, performance, stability, and reliability. Oracle Database 19c offers significant enhancements, bug fixes, and new features unavailable in the 11g version. Upgrading to 19.20.0.0 ensures continued support and compatibility with modern systems and provides a more efficient and secure database environment.

What is the timeline for this upgrade?

This upgrade is available as a stable upgrade on November 8, 2023.

Will I be impacted?

Yes, if you use the default version, you will be impacted. The impact might be minimal if you use the latest driver or a higher version than 19c.

Do I need to reconfigure my accounts?

You do not have to reconfigure your account settings or drivers; the account can remain as-is to work with the latest driver. However, if you currently use the default version and want to revert to the previous version behavior, we recommend you use the OJDBC6 JAR.

How do you override the behavior changes?

Use the OJDBC6 JAR from the 11.2.0.4 version to maintain the same behavior as before the driver upgrade:

...

Behavior Changes

This driver upgrade has resulted in specific behavior changes within in the Snap Pack. These changes are related to for status codes and success and failure messages. This table lists these changes:

Scenario in

Oracle Snaps

Scenario

Error/Output from the Old

Oracle

(OJDBC6 JAR—11.2.0.4 version) JDBC Driver

Error

after the Oracle Driver and JOOQ upgrade

Oracle - Insert: For the insert operation, when you enter a string value instead of an integer in a numeric column.

Error Message: SQL operation failed.

Reason: ORA-01722: invalid number , error code: 1722, Coracle-Insert ? BH D7 A ® 'SQL state: 42000,

Resolution: Please check for valid Snap properties and input data.

Error Message: Invalid integer: <string>

Reason: The string value is not a number.

Resolution: <Please address the reported issue.>

Aravind Koonapureddy (Deactivated) - Can you update the resolution for this msg as follows:
<Provide a valid integer value in the input data.>

Oracle - Execute, Oracle - Insert, and Oracle - Merge: When the execute, insert,

/Output from the new (OJDBC10 JAR —19.20.0.0 version) JDBC Driver

Oracle-Execute

jOOQ upgrade change:

When you use a stored procedure.

Output message:

Message: Success

Output message:

$UPDATE_COUNT=-1.

Oracle - Execute

Oracle - Insert

Oracle - Merge

When the insert and merge operations are successful.

Output message:

  • Status: "-2"

  • Message: Batch statement executed successfully, but no count of the number of rows it affected is available.

Output message:

  • Status: 1

  • Message: success

Oracle - Delete

,

Oracle -

Insert, Oracle - Execute, and

Execute

Oracle - Update

:

When the delete

, insert, update, and execute

and update operations are successful.

Output message:

  • Status: "-2"

  • Message: Batch statement executed successfully, but no count of the number of rows it affected is available.

Output message:

  • Status: "number of rows impacted"

  • Message: success

Oracle - Insert

: When the insert operation fails.

 

Case 1:Insert batch records into non-Oracle - Execute and Oracle - Insert:Batch operation when

When you enter a string value instead of an integer in a numeric column for the insert operation.

Error message: SQL operation failed.

Reason: ORA-01722: invalid number , error code: 1722, Coracle-Insert ? BH D7 A ® 'SQL state: 42000,

Resolution: Please check for valid Snap properties and input data.

Error Message: Invalid integer: <string>

Reason: The string value is not a number.

Resolution: Please address the reported issue.

Oracle - Insert

 

When you insert null values into the not null column type.

Error message:

Insert batch records into not null column type- one record specified with null value to fail and route to error view.

Case 1:The errors are the same in both drivers, but the reason is repeated twice inolder drivers.

Reason: ORA-01400: cannot insert NULL into (&quot;<table name>$#&quot;.&quot;ORACLECHAR_NOTNULL&quot;.&quot;COLUMN1&quot;) , error code: 1400, SQL state: 23000, next exception: ORA-01400: cannot insert NULL into (&quot;<table_name>$#&quot;.&quot;ORACLECHAR_NOTNULL&quot;.&quot;COLUMN1&quot;) },

The reason is repeated twice with the ‘next exception key inolder drivers.

Reason: ORA-01400: cannot insert NULL into (&quot;<table_name>$#&quot;.&quot;ORACLECHAR_NOTNULL&quot;.&quot;COLUMN1&quot;) , error code: 1400, SQL state: 23000, next exception: ORA-01400: cannot insert NULL into (&quot;<table name>$#&quot;.&quot;ORACLECHAR_NOTNULL&quot;.&quot;COLUMN1&quot;) },

Oracle - Execute

Oracle - Insert

 

Batch operation when the Auto commit checkbox is Selected.

 

Error message: Batch operation failed

In the old version,the entire batch fails when an error

record

occurs during a batch operation

, the entire batch fails

, and records are redirected to the error view. As a result, no records are inserted into the database.

Error message: SQL operation failed

In the new version, if

there is

an error

record

occurs in the batch operation, the records before the problematic one are inserted into the database,

while

and the records after it are routed to the error view.

Records are inserted into the table because the Auto-commit checkbox is selected.

Oracle - Execute

and

Oracle - Insert

:

Batch operation when the Auto Commit checkbox isDeselected.

Error message: 'Batch operation failed'

In the old version,when an error

record

occurs during a batch operation, the entire batch fails and records are redirected to the error view. As a result, no records are inserted into the database.

Error message: 'SQL operation failed'

In the new version, if

there is

an error

record

occurs in the batch operation, the records before the problematic one are inserted into the database,

while

and the records after it are routed to the error view.

Records are not inserted into the table because the Auto-commit checkbox is deselected.

Oracle - Select

When you select a second output view for metadata.

Displays the data type as DECIMALfor numeric columns.

New driver displays

Displays data type as "NUMERIC" instead of "DECIMAL".

Oracle - Execute

:

Insert operation

When

when you pass a spl character ( ' ):

"reason=

Reason: Invalid query: Insert into #TABLE_NAME.COLUMN_NAME# values ('windyi'eee')"

"reason=

.

Resolution: Please check for valid Snap properties and input data.

Error code: 17081

Reason: error occurred during batching: ORA-00917: missing comma"

Resolution: Please check for valid Snap properties and input data.

Oracle - Delete

Delete

_Condition

condition contains special characters

:"{reason=

.

Reason: Syntax error at or near one of single-quotes}"

"{reason=

Error code: 1740

Reason: ORA-01740: missing double quote in identifier


, error code: 1740

, SQL state: 42000}"

FAQ for Upgrading from Oracle JDBC 11.2.0.4 Driver to 19.20.0.0 Driver

What is happening?

The Oracle JDBC Driver is upgraded from OJDBC6 JAR (11.2.0.4 version) to the OJDBC10 JAR (19.20.0.0 version). The OJDBC10 JAR is bundled with the Oracle Snap Pack as the default driver.

Why are we upgrading the Oracle driver?

The decision to upgrade the Oracle JDBC driver from version 11.2.0.4 to 19.20.0.0 is made to improve security, performance, stability, and reliability. Oracle Database 19c offers significant enhancements, bug fixes, and new features unavailable in the 11g version. Upgrading to 19.20.0.0 ensures continued support and compatibility with modern systems and provides a more efficient and secure database environment.

What is the timeline for this upgrade?

This upgrade is available as a stable upgrade for November 8, 2023, while you can have an early preview available shortly after the August 2023 GA release.

Will I be impacted?

If you are using the default version, you will be impacted. The impact may be minimal if you utilize the latest driver or a higher version than 19c.

Do I need to reconfigure my accounts?

You do not have to reconfigure your account settings or drivers; the account can remain as-is to work with the latest driver. However, if you currently use the default version and wish to revert to the previous version behavior, we recommend you to use the OJDBC6 JAR.

How do you override the behavior changes?

...