blob: 0c7c891f4b1e0911d16942ea0338c19b1c5caa28 [file] [log] [blame] [view]
<!---
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied. See the License for the
specific language governing permissions and limitations
under the License.
-->
# Extensions List
DataFusion tries to provide a good set of features "out of the box" to quickly
start with a working system, but it can't include every useful feature (e.g.
`TableProvider`s for all data formats).
Thankfully one of the core features of DataFusion is a flexible extension API
that allows users to extend its behavior at all points. This page lists some
community maintained extensions available for DataFusion. These extensions are
not part of the core DataFusion project, and not under Apache Software
Foundation governance but we list them here to be useful to others in the
community.
If you know of an available extension that is not listed below, please open a PR
to add it to this page. If there is some feature you would like to see in
DataFusion, please consider creating a new extension in the `datafusion-contrib`
project (see [below](#datafusion-contrib)). Please [contact] us via github issue, slack, or Discord and
we'll gladly set up a new repository for your extension.
| Name | Type | Description |
| ---------------------------- | ----------------- | --------------------------------------------------------------------------------- |
| [DataFusion Table Providers] | [`TableProvider`] | Support for `PostgreSQL`, `MySQL`, `SQLite`, `DuckDB`, and `Flight SQL` |
| [DataFusion Federation] | Framework | Allows DataFusion to execute (part of) a query plan by a remote execution engine. |
| [DataFusion ORC] | [`TableProvider`] | [Apache ORC] file format |
| [DataFusion JSON Functions] | Functions | Scalar functions for querying JSON strings |
[`tableprovider`]: https://docs.rs/datafusion/latest/datafusion/catalog/trait.TableProvider.html
[datafusion table providers]: https://github.com/datafusion-contrib/datafusion-table-providers
[datafusion federation]: https://github.com/datafusion-contrib/datafusion-federation
[datafusion orc]: https://github.com/datafusion-contrib/datafusion-orc
[apache orc]: https://orc.apache.org/
[datafusion json functions]: https://github.com/datafusion-contrib/datafusion-functions-json
## `datafusion-contrib`
The [`datafusion-contrib`] project contains a collection of community maintained
extensions that are not part of the core DataFusion project, and not under
Apache Software Foundation governance but may be useful to others in the
community. If you are interested adding a feature to DataFusion, a new extension
in `datafusion-contrib` is likely a good place to start. Please [contact] us via
github issue, slack, or Discord and we'll gladly set up a new repository for
your extension.
[`datafusion-contrib`]: https://github.com/datafusion-contrib
[contact]: ../contributor-guide/communication.md