Skip to main content

Database & Async Runtime

First, add sea-orm-x to the [dependencies] section of Cargo.toml.

Cargo.toml
sea-orm = { version = "0.12", path = "<SEA_ORM_X_ROOT>/sea-orm-x", features = [ <DATABASE_DRIVER>, <ASYNC_RUNTIME>, "macros" ] }

You must choose a DATABASE_DRIVER and an ASYNC_RUNTIME. macros is needed if you use SeaORM's generated entities (most likely).

DATABASE_DRIVER

You can choose one or more from:

  • sqlz-mssql - SQLz MSSQL

ASYNC_RUNTIME

You have to choose one from:

runtime-async-std-native-tls, runtime-tokio-native-tls, runtime-async-std-rustls, runtime-tokio-rustls

Basically, they are in the form of runtime-ASYNC_RUNTIME-TLS_LIB:

  1. Choose the ASYNC_RUNTIME corresponding to your Rust web framework:
ASYNC_RUNTIMEWeb Framework
async-stdTide
tokioAxum, Actix, Poem, Rocket
  1. native-tls uses the platform's native security facilities, while rustls is an (almost) pure Rust implementation.

Extra features

  • debug-print - print every SQL statement to logger
  • mock - mock interface for unit testing
  • macros - procedural macros for your convenient
  • with-chrono - support chrono types
  • with-time - support time types
  • with-json - support serde-json types
  • with-rust_decimal - support rust_decimal types
  • with-bigdecimal - support bigdecimal types
  • with-uuid - support uuid types
  • postgres-array - support array types in Postgres (automatically enabled when sqlx-postgres feature is turned on)
  • sea-orm-internal - opt-in unstable internal APIs (for accessing re-export SQLx types)