Skip to content

Database connectivity API standard and libraries for Apache Arrow

License

Apache-2.0, Apache-2.0 licenses found

Licenses found

Apache-2.0
LICENSE.txt
Apache-2.0
license.tpl
Notifications You must be signed in to change notification settings

birschick-bq/arrow-adbc

This branch is 2 commits behind apache/arrow-adbc:main.

Folders and files

NameName
Last commit message
Last commit date
Feb 14, 2025
Mar 3, 2025
Feb 26, 2025
Mar 3, 2025
Mar 3, 2025
Mar 3, 2025
Jan 22, 2025
Mar 3, 2025
Mar 4, 2025
Feb 26, 2025
Feb 26, 2025
Jan 22, 2025
Feb 18, 2025
Feb 2, 2024
Sep 29, 2023
Jun 1, 2022
Jun 25, 2024
Jun 1, 2022
Feb 26, 2025
Jun 24, 2022
Feb 14, 2025
Oct 29, 2024
Feb 2, 2024
May 4, 2023
Feb 26, 2025
Jan 22, 2025
Oct 4, 2024
Mar 26, 2024
Dec 11, 2022
Oct 9, 2024
Jan 20, 2025
Mar 26, 2024
Jun 15, 2023

ADBC: Arrow Database Connectivity

License

ADBC is an API standard (version 1.0.0) for database access libraries ("drivers") in C, Go, and Java that uses Arrow for result sets and query parameters. Instead of writing code to convert to and from Arrow data for each individual database, applications can build against the ADBC APIs, and link against drivers that implement the standard. Additionally, a JDBC/ODBC-style driver manager is provided. This also implements the ADBC APIs, but dynamically loads drivers and dispatches calls to them.

Like JDBC/ODBC, the goal is to provide a generic API for multiple databases. ADBC, however, is focused on bulk columnar data retrieval and ingestion through an Arrow-based API rather than attempting to replace JDBC/ODBC in all use cases. Hence, ADBC is complementary to those existing standards.

Like Arrow Flight SQL, ADBC is an Arrow-based way to work with databases. However, Flight SQL is a protocol defining a wire format and network transport as opposed to an API specification. Flight SQL requires a database to specifically implement support for it, while ADBC is a client API specification for wrapping existing database protocols which could be Arrow-native or not. Together, ADBC and Flight SQL offer a fully Arrow-native solution for clients and database vendors.

For more about ADBC, see the introductory blog post.

Status

ADBC versions the API standard and the implementing libraries separately.

The API standard (version 1.0.0) is considered stable, but enhancements may be made.

Libraries are under development. For more details, see the documentation, or read the changelog.

Installation

Please see the documentation.

Documentation

The core API definitions can be read in adbc.h. User documentation can be found at https://arrow.apache.org/adbc

Development and Contributing

For detailed instructions on how to build the various ADBC libraries, see CONTRIBUTING.md.

About

Database connectivity API standard and libraries for Apache Arrow

Resources

License

Apache-2.0, Apache-2.0 licenses found

Licenses found

Apache-2.0
LICENSE.txt
Apache-2.0
license.tpl

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C# 38.9%
  • C++ 17.0%
  • Go 11.2%
  • C 6.6%
  • Java 6.5%
  • Rust 5.8%
  • Other 14.0%