OceanBase logo

OceanBase

A unified distributed database ready for your transactional, analytical, and AI workloads.

DEPLOY YOUR WAY

OceanBase Cloud

The best way to deploy and scale OceanBase

OceanBase Enterprise

Run and manage OceanBase on your infra

TRY OPEN SOURCE

OceanBase Community Edition

The free, open-source distributed database

OceanBase seekdb

Open source AI native search database

Customer Stories

Real-world success stories from enterprises across diverse industries.

View All
BY USE CASES

Mission-Critical Transactions

Global & Multicloud Application

Elastic Scaling for Peak Traffic

Real-time Analytics

Active Geo-redundancy

Database Consolidation

Resources

Comprehensive knowledge hub for OceanBase.

Blog

Live Demos

Training & Certification

Documentation

Official technical guides, tutorials, API references, and manuals for all OceanBase products.

View All
PRODUCTS

OceanBase Cloud

OceanBase Database

Tools

Connectors and Middleware

QUICK START

OceanBase Cloud

OceanBase Database

BEST PRACTICES

Practical guides for utilizing OceanBase more effectively and conveniently

Company

Learn more about OceanBase – our company, partnerships, and trust and security initiatives.

About OceanBase

Partner

Trust Center

Contact Us

International - English
中国站 - 简体中文
日本 - 日本語
Sign In
Start on Cloud

A unified distributed database ready for your transactional, analytical, and AI workloads.

DEPLOY YOUR WAY

OceanBase Cloud

The best way to deploy and scale OceanBase

OceanBase Enterprise

Run and manage OceanBase on your infra

TRY OPEN SOURCE

OceanBase Community Edition

The free, open-source distributed database

OceanBase seekdb

Open source AI native search database

Customer Stories

Real-world success stories from enterprises across diverse industries.

View All
BY USE CASES

Mission-Critical Transactions

Global & Multicloud Application

Elastic Scaling for Peak Traffic

Real-time Analytics

Active Geo-redundancy

Database Consolidation

Comprehensive knowledge hub for OceanBase.

Blog

Live Demos

Training & Certification

Documentation

Official technical guides, tutorials, API references, and manuals for all OceanBase products.

View All
PRODUCTS
OceanBase CloudOceanBase Database
ToolsConnectors and Middleware
QUICK START
OceanBase CloudOceanBase Database
BEST PRACTICES

Practical guides for utilizing OceanBase more effectively and conveniently

Learn more about OceanBase – our company, partnerships, and trust and security initiatives.

About OceanBase

Partner

Trust Center

Contact Us

Start on Cloud
编组
All Products
    • Databases
    • iconOceanBase Database
    • iconOceanBase Cloud
    • iconOceanBase Tugraph
    • iconInteractive Tutorials
    • iconOceanBase Best Practices
    • Tools
    • iconOceanBase Cloud Platform
    • iconOceanBase Migration Service
    • iconOceanBase Developer Center
    • iconOceanBase Migration Assessment
    • iconOceanBase Admin Tool
    • iconOceanBase Loader and Dumper
    • iconOceanBase Deployer
    • iconKubernetes operator for OceanBase
    • iconOceanBase Diagnostic Tool
    • iconOceanBase Binlog Service
    • Connectors and Middleware
    • iconOceanBase Database Proxy
    • iconEmbedded SQL in C for OceanBase
    • iconOceanBase Call Interface
    • iconOceanBase Connector/C
    • iconOceanBase Connector/J
    • iconOceanBase Connector/ODBC
    • iconOceanBase Connector/NET
icon

OceanBase Connector/J

V2.4.3

  • What is OceanBase Connector J?
    • Overview of OceanBase Connector/J
    • Compatibility requirements
  • Install Driver
    • Install and load the OceanBase Connector/J driver
  • Instructions
    • Quick start
      • Import packages
      • Create a Statement object
      • Process ResultSet objects
      • Run queries and retrieve ResultSet objects
      • Commit changes
      • Example
      • Manage tables and data
      • Close a database connection
      • Close ResultSet and Statement objects
      • Create a database connection
    • Data sources and URL
      • Data source overview
      • Database URL
    • Java data streams
      • CHAR, VARCHAR, and RAW data types
      • Overview of Java data streams
      • LONG and LONG RAW data types
      • Use LOBs
        • Overview of LOB data types
        • LOB data interface
        • LOB locator API
    • Statement caching
      • Overview of statement caching
      • Use statement caching
      • Reuse statement objects
    • Call a stored procedure
    • Handle SQL exceptions
    • Result set
      • Overview of result sets
      • Limitations
      • FetchSize
      • refreshRow
      • useCursorFetch
    • Batch processing
    • Failover and Load-Balancing
      • Load balancing strategy configuration methods
      • Failover and load balancing modes
      • LoadBalance strategies
    • Security features
    • Rich client
    • Network overheads
    • Show Trace
    • Troubleshooting
  • Reference
    • Supported SQL and PL data types
    • Features specific to the Oracle mode
      • Binary Protocol (Prepared Statements)
        • COM_STMT_SEND_PIECE_DATA
        • COM_STMT_PREPARE_EXECUTE
      • Call PL stored procedures
      • Scrollability of a result set
      • Use ARRAY and STRUCT classes
      • Distributed transactions
        • Distributed transaction examples
        • XA components
        • Overview
      • Obtain comments
      • Data types supported in Oracle mode
      • Error messages in Oracle mode
    • Common APIs
      • java.sql.PreparedStatement
      • javax.naming.Context
      • java.sql.Statement
      • javax.sql.PooledConnection
      • java.sql.ParameterMetaData
      • java.sql.CallableStatement
      • java.sql.ResultSetMetaData
      • java.sql.ResultSet
      • Overview
      • java.sql.Driver
      • java.sql.Connection
      • javax.sql.ConnectionPoolDataSource
      • java.sql.DatabaseMetaData
  • Release
    • V2.4
      • OceanBase Connector/J V2.4.3
      • OceanBase Connector/J V2.4.2
      • OceanBase Connector/J V2.4.1
      • OceanBase Connector/J V2.4.0
    • V2.2
      • OceanBase Connector/J V2.2.10
      • OceanBase Connector/J V2.2.7
      • OceanBase Connector/J V2.2.3
      • OceanBase Connector/J V2.2.6
      • OceanBase Connector/J V2.2.11
      • OceanBase Connector/J V2.2.0

Download PDF

Overview of OceanBase Connector/J Compatibility requirements Install and load the OceanBase Connector/J driver Import packages Create a Statement object Process ResultSet objects Run queries and retrieve ResultSet objects Commit changes Example Manage tables and data Close a database connection Close ResultSet and Statement objects Create a database connection Data source overviewDatabase URL CHAR, VARCHAR, and RAW data types Overview of Java data streams LONG and LONG RAW data types Overview of statement caching Use statement caching Reuse statement objects Call a stored procedure Handle SQL exceptions Overview of result sets Limitations FetchSize refreshRow useCursorFetch Batch processing Load balancing strategy configuration methods Failover and load balancing modes LoadBalance strategies Security features Rich client Network overheads Show Trace Troubleshooting Supported SQL and PL data types Call PL stored procedures Scrollability of a result set Use ARRAY and STRUCT classes Obtain comments Data types supported in Oracle mode Error messages in Oracle mode java.sql.PreparedStatement javax.naming.Context java.sql.Statement javax.sql.PooledConnection java.sql.ParameterMetaData java.sql.CallableStatement java.sql.ResultSetMetaData java.sql.ResultSet Overview java.sql.Driver java.sql.Connection javax.sql.ConnectionPoolDataSource java.sql.DatabaseMetaData OceanBase Connector/J V2.4.3 OceanBase Connector/J V2.4.2 OceanBase Connector/J V2.4.1 OceanBase Connector/J V2.4.0 OceanBase Connector/J V2.2.10 OceanBase Connector/J V2.2.7 OceanBase Connector/J V2.2.3 OceanBase Connector/J V2.2.6 OceanBase Connector/J V2.2.11 OceanBase Connector/J V2.2.0
OceanBase logo

The Unified Distributed Database for the AI Era.

Follow Us
Products
OceanBase CloudOceanBase EnterpriseOceanBase Community EditionOceanBase seekdb
Resources
DocsBlogLive DemosTraining & Certification
Company
About OceanBaseTrust CenterLegalPartnerContact Us
Follow Us

© OceanBase 2026. All rights reserved

Cloud Service AgreementPrivacy PolicySecurity
Contact Us
Document Feedback
  1. Documentation Center
  2. OceanBase Connector/J
  3. V2.4.3
iconOceanBase Connector/J
V 2.4.3
  • V 2.4.17
  • V 2.4.16
  • V 2.4.15
  • V 2.4.14
  • V 2.4.5
  • V 2.4.4
  • V 2.4.3
  • V 2.4.2
  • V 2.4.1
  • V 2.4.0
  • V 2.2.11
  • V 2.2.10
  • V 2.2.7
  • V 2.2.6
  • V 2.2.3
  • V 2.2.0

Limitations

Last Updated:2026-04-09 07:21:44  Updated
share
What is on this page
Result set limitations
Verify the result set type
Avoid update conflicts

folded

share

Some types of result sets are not applicable to some queries. If an unavailable result set type or concurrency type is specified for a query, OceanBase Connector/J will follow some rules to choose the best feasible result set type for the query.

The actual result set type and concurrency type are determined when the statement is executed. If the required result set type or concurrency type is unavailable, the driver will issue SQLWarning on the statement object. The SQLWarning object contains the reason why the requested type is unavailable. Check the alerts to verify whether you have received the result set of the requested type.

Result set limitations

Queries on the result set are subject to the following limitations. If a query fails to follow these guidelines, OceanBase Connector/J will select an alternate result set type or concurrency type.

  • Limitations on generating updatable result sets:

    • A query can select data only from a single table and cannot contain any join operations. In addition, to perform an insert operation, the query must select all non-nullable columns and all columns without default values.

    • SELECT * cannot be used in a query. You can use table aliases in a query, as shown in the following example:

      SELECT tab.* FROM TABLE tab ...
      
    • A query must select only table columns, and cannot select derived columns or aggregates, such as a group of columns in SUM or MAX.

  • Limitations on generating scroll-sensitive result sets:

    • SELECT * cannot be used in a query. You can use table aliases in a query, as shown in the following example:

      SELECT tab.* FROM TABLE tab ...
      
    • A query can select data only from a single table.

In Oracle mode, you can use the following method to determine whether a query may generate a scroll-sensitive or updatable result set. If you can add the ROWID column to the query list without causing any exceptions, the query may generate a scroll-sensitive or updatable result set.

Verify the result set type

Note

Any operation of OceanBase Connector/J on the result set type is independent of that on the concurrency type.

After a query is executed, you can check the result set type and concurrency type actually used by OceanBase Connector/J by calling the following methods on the result set object:

  • int getType() throws SQLException

    This method returns the int value of the result set type for the query. Possible values: ResultSet.TYPE_FORWARD_ONLY, ResultSet.TYPE_SCROLL_SENSITIVE, and ResultSet.TYPE_SCROLL_INSENSITIVE.

  • int getConcurrency() throws SQLException

    This method returns the int value of the concurrency type for the query. Possible values: ResultSet.CONCUR_READ_ONLY and ResultSet.CONCUR_UPDATABLE.

Avoid update conflicts

Note the following limitations on updatable result sets:

  • The driver does not enforce write locking on updatable result sets.

  • The driver does not check conflicts with DELETE and UPDATE operations on result sets.

If you attempt to execute a DELETE or UPDATE operation on rows of another committed transaction, a conflict will occur.

In MySQL mode, a row is uniquely identified by the primary key in the result set. If no primary key is available, the row cannot be updated. When the driver issues an UPDATE or DELETE operation to the database, the operation will be executed provided that the primary key is valid.

In Oracle mode, ROWID is used to uniquely identify a row in a database table. When the driver issues an UPDATE or DELETE operation to the database, the operation will be executed provided that ROWID is valid.

The driver will not report any changes made by other committed transactions and your changes will overwrite previous changes. To avoid such conflicts, we recommend that you use the FOR UPDATE feature when you query for generated result sets. However, it will also prevent simultaneous data access. A data item can retain only one write lock at a time.

Previous topic

Overview of result sets
Last

Next topic

FetchSize
Next
What is on this page
Result set limitations
Verify the result set type
Avoid update conflicts