Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jupyter-xeus/xeus-sql
Jupyter kernel for SQL databases
https://github.com/jupyter-xeus/xeus-sql
db2 firebird mysql odbc postgresql sql sqlite
Last synced: 4 days ago
JSON representation
Jupyter kernel for SQL databases
- Host: GitHub
- URL: https://github.com/jupyter-xeus/xeus-sql
- Owner: jupyter-xeus
- License: bsd-3-clause
- Created: 2020-12-01T21:44:25.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-12-16T08:46:03.000Z (28 days ago)
- Last Synced: 2024-12-25T13:14:41.314Z (19 days ago)
- Topics: db2, firebird, mysql, odbc, postgresql, sql, sqlite
- Language: C++
- Homepage: https://xeus-sql.readthedocs.io/en/latest/
- Size: 4.58 MB
- Stars: 168
- Watchers: 8
- Forks: 22
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - jupyter-xeus/xeus-sql - Jupyter kernel for SQL databases (sql)
README
# xeus-sql
[![GithubActions](https://github.com/jupyter-xeus/xeus-sql/actions/workflows/main.yml/badge.svg)](https://github.com/jupyter-xeus/xeus-sql/actions/workflows/main.yml)
[![Join the chat at https://gitter.im/QuantStack/Lobby](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/QuantStack/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
[![Documentation Status](https://readthedocs.org/projects/xeus-sql/badge/?version=latest)](https://xeus-sql.readthedocs.io/en/latest/?badge=latest)
[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/jupyter-xeus/xeus-sql/stable?urlpath=lab/tree/examples/SQLite.ipynb)`xeus-sql` is a Jupyter kernel for general SQL implementations based on the native implementation of the Jupyter protocol [xeus](https://github.com/jupyter-xeus/xeus) and [SOCI](https://github.com/SOCI/soci), a database access library for C++.
![xeus-sql screencast](xeus-sql-screencast.gif)
## Usage
Launch the Jupyter notebook with `jupyter notebook` or Jupyter lab with `jupyter lab` and launch a new SQL notebook by selecting the **xsql** kernel.
Note that `xeus-sql` support the following SQL implementations:
* DB2
* Firebird
* MySQL
* ODBC (generic backend)
* Oracle
* PostgreSQL
* SQLite3## Installation
`xeus-sql` has been packaged for the mamba (or conda) package manager.
To ensure that the installation works, it is preferable to install `xeus-sql` in a fresh environment.
To ensure that the installation works, it is preferable to install `xeus` in a fresh environment. It is also needed to use
a [miniforge](https://github.com/conda-forge/miniforge#mambaforge) or [miniconda](https://conda.io/miniconda.html) installation because with the full [anaconda](https://www.anaconda.com/)
you may have a conflict.The safest usage is to create an environment named `xeus-sql`
```
mamba create -n xeus-sql
source activate xeus-sql
```### Installing from conda-forge
To install xeus-sql with the mamba (or conda) package manager:
```
mamba install xeus-sql jupyterlab -c conda-forge
```With mamba:
```
mamba install xeus-sql jupyterlab -c conda-forge
```Conda forge offers packaged versions for MySQL, PostgreSQL and SQLite and you can download them with: `soci-mysql`, `soci-postgresql` or `soci-sqlite`.
`xeus-sql` includes `soci-core` only. Which consists on the SOCI package with no DB extension attached.
## Documentation
https://xeus-sql.readthedocs.io/en/latest/
## Dependencies
``xeus-sql`` depends on
- [xeus](https://github.com/jupyter-xeus/xeus)
- [Tabulate](https://github.com/p-ranav/tabulate)
- [xvega](https://github.com/Quantstack/xvega)
- [SQLite\*](https://github.com/sqlite/sqlite)
- [PostgreSQL\*](https://github.com/postgres)
- [MySQL\*](https://github.com/mysql/mysql-server)##### xeus dependencies
| `xeus-sql` | `xeus-zmq` | `tabulate` | `nlohmann_json` | `xproperty` | `xvega-bindings` | `soci-core` |
|------------|-----------------|----------------|--------------------|-------------|------------------|-------------|
| main | >=3.1.0, <4.0 | >=1.4\|>=3.0.0 | >= 0.0.10, <3.10.0 | >=0.11.0 | >=0.0.10 | >=4.0.1 |
| 0.3.0 | >=3.1.0, <4.0 | >=1.4\|>=3.0.0 | >= 0.0.10, <3.10.0 | >=0.11.0 | >=0.0.10 | >=4.0.1 |
| 0.2.1 | >=1.0.1, <2.0 | >=1.4\|>=3.0.0 | >= 0.0.10, <3.10.0 | >=0.11.0 | >=0.0.10 | >=4.0.1 |
| 0.2.0 | >=1.0.1, <2.0 | >=1.4\|>=3.0.0 | >= 0.0.10, <3.10.0 | >=0.11.0 | >=0.0.10 | >=4.0.1 |Prior to version 0.2, xeus-sql was depending on
| `xeus-sql` | `xeus` | `tabulate` | `nlohmann_json` | `xproperty` | `xvega-bindings` | `soci-core` |
|------------|-----------------|----------------|--------------------|-------------|------------------|-------------|
| <=0.1.5 | >=2.0.0, <3.0 | >=1.4\|>=3.0.0 | >= 0.0.10, <3.10.0 | >=0.10.4 | >=0.0.10 | >=4.0.1 |
| <=0.1.2 | >=1.0.0, <2.0 | >=1.4\|>=3.0.0 | >= 0.0.10 \| 4.0.1 | >=0.10.4 | >=0.0.10 | >=4.0.1 |
| <=0.0.6 | >=0.24.0, <0.25 | >=1.4\|>=3.0.0 | >= 0.0.5 \| 4.0.1 | >=0.10.4 | >=0.0.3 | >=4.0.1 |##### SQL dependencies
These are optional dependencies that come by default with `xeus-sql` but may or may not be added to your project in case you're building manually. For more information check the CONTRIBUTING file.
| `xeus-sql` | `PostgreSQL` | `SQLite` | `MySQL` | `soci-sqlite`, `soci-postgres`, `soci-mysql` |
|------------|--------------|-------------|--------------|----------------------------------------------|
| main | >=3.30.1, <4 | >=3.0.0, <4 | >=1.3.0,<2.0 | >=4.0.1 |
| <=0.1.5 | >=3.30.1, <4 | >=3.0.0, <4 | >=1.3.0,<2.0 | >=4.0.1 |## Contributing
See [CONTRIBUTING.md](./CONTRIBUTING.md) to know how to contribute and set up a development environment.
## License
We use a shared copyright model that enables all contributors to maintain the
copyright on their contributions.This software is licensed under the BSD-3-Clause license. See the [LICENSE](LICENSE) file for details.