Skip to content

Commit

Permalink
Documentation: Improve page about migrating to sqlalchemy-cratedb
Browse files Browse the repository at this point in the history
  • Loading branch information
amotl committed Nov 15, 2024
1 parent b6d9d1b commit 2464550
Showing 1 changed file with 29 additions and 31 deletions.
60 changes: 29 additions & 31 deletions docs/migrate-from-crate-client.md
Original file line number Diff line number Diff line change
@@ -1,54 +1,52 @@
(migrate-from-crate-python)=
# Migrate from `crate.client`

## Introduction
In June 2024, code from the package [crate\[sqlalchemy\]] has been transferred
to the package [sqlalchemy-cratedb]. For 80% of use cases, this will be
a drop-in replacement with no noticeable changes.

However, if you use CrateDB's special data types like `OBJECT`, `ARRAY`,
`GEO_POINT`, or `GEO_SHAPE`, and imported the relevant symbols from
`crate.client.sqlalchemy`, you will need to import the same symbols from
`sqlalchemy_cratedb` from now on.
With the release of `crate-1.0.0` in November 2024, the SQLAlchemy dialect was
dropped from this package. See the "Upgrade procedure" section for further
information.

## Upgrade procedure

- Swap dependency definition from `crate[sqlalchemy]` to `sqlalchemy-cratedb`
in your `pyproject.toml`, `requirements.txt`, or `setup.py`.
- Adjust symbol imports as outlined below.

### Symbol import adjustments
```python
# Previous import
# from crate.client.sqlalchemy.dialect import CrateDialect

# New import
from sqlalchemy_cratedb import dialect
In order to continue using the CrateDB SQLAlchemy dialect, please install the
`sqlalchemy-cratedb` package [^1].
```shell
pip install --upgrade sqlalchemy-cratedb
```

```python
# Previous import
# from crate.client.sqlalchemy.types import ObjectArray, ObjectType, FloatVector, Geopoint, Geoshape

# New import
from sqlalchemy_cratedb import ObjectArray, ObjectType, FloatVector, Geopoint, Geoshape
```
## Code changes
If you are using CrateDB's special data types like `OBJECT`, `ARRAY`,
`GEO_POINT`, or `GEO_SHAPE`, and imported the relevant symbols from
`crate.client.sqlalchemy` before, you will need to adjust your imports
to use `sqlalchemy_cratedb` from now on, as outlined below.

### Previous imports
```python
# Previous import
from crate.client.sqlalchemy.dialect import CrateDialect
from crate.client.sqlalchemy.types import ObjectArray, ObjectType, FloatVector, Geopoint, Geoshape
from crate.client.sqlalchemy.predicates import match
from crate.client.sqlalchemy.compiler import CrateDDLCompiler, CrateTypeCompiler

# New import
from sqlalchemy_cratedb.compiler import CrateDDLCompiler, CrateTypeCompiler
```

### New imports
```python
# Previous import
# from crate.client.sqlalchemy.predicates import match

# New import
from sqlalchemy_cratedb import dialect
from sqlalchemy_cratedb import ObjectArray, ObjectType, FloatVector, Geopoint, Geoshape
from sqlalchemy_cratedb import knn_match, match
from sqlalchemy_cratedb.compiler import CrateDDLCompiler, CrateTypeCompiler
```


[crate\[sqlalchemy\]]: https://pypi.org/project/crate/
[d2c42031f]: https://github.com/crate/cratedb-examples/commit/d2c42031f
[sqlalchemy-cratedb]: https://pypi.org/project/sqlalchemy-cratedb/

[^1]: When applicable, please also update your project dependencies to use
`sqlalchemy-cratedb` in your `pyproject.toml`, `requirements.txt`, or
`setup.py` files, **instead** of using the previous `crate[sqlalchemy]`
package. `sqlalchemy-cratedb` lists `crate` as a dependency and will
automatically pull in the right version. A typical dependency update will
look like [d2c42031f].

0 comments on commit 2464550

Please sign in to comment.