Skip to main content

DatabaseConnection

Struct DatabaseConnection 

Source
pub struct DatabaseConnection { /* private fields */ }
Available on crate feature database and native only.
Expand description

Database connection wrapper

Implementations§

Source§

impl DatabaseConnection

Source

pub fn new(backend: Arc<dyn DatabaseBackend>) -> DatabaseConnection

Creates a new instance.

Defaults to is_cockroachdb = false, which is the correct choice when the caller has not (or cannot) probe the server. If the supplied backend is known to be CockroachDB, use Self::new_with_flavor instead so the migration recorder routes through the sentinel-row lock path rather than pg_advisory_lock (issue #4642).

Source

pub fn new_with_flavor( backend: Arc<dyn DatabaseBackend>, is_cockroachdb: bool, ) -> DatabaseConnection

Creates a new instance with an explicit CockroachDB flavor flag.

Use this when wrapping an externally constructed Postgres backend whose flavor is already known — e.g. tests that mount a CockroachDB pool, or adapters that pre-probe SELECT version() themselves.

Source

pub async fn connect_postgres( url: &str, ) -> Result<DatabaseConnection, DatabaseError>

Available on crate feature postgres only.

Connects to postgres.

Source

pub async fn connect_postgres_with_pool_size( url: &str, pool_size: Option<u32>, ) -> Result<DatabaseConnection, DatabaseError>

Available on crate feature postgres only.

Connects to postgres with pool size.

Source

pub async fn connect_postgres_or_create( url: &str, ) -> Result<DatabaseConnection, DatabaseError>

Available on crate feature postgres only.

Connect to PostgreSQL with automatic database creation if it doesn’t exist.

This method first attempts to connect to the specified database. If the connection fails due to the database not existing, it will:

  1. Connect to the default postgres database
  2. Create the target database
  3. Reconnect to the newly created database
§Arguments
  • url - PostgreSQL connection URL (e.g., “postgres://user:pass@localhost/mydb”)
§Example
use reinhardt_db::backends::connection::DatabaseConnection;

// Will create 'mydb' if it doesn't exist
let conn = DatabaseConnection::connect_postgres_or_create(
    "postgres://postgres@localhost/mydb"
).await?;
Source

pub async fn connect_postgres_or_create_with_pool_size( url: &str, pool_size: Option<u32>, ) -> Result<DatabaseConnection, DatabaseError>

Available on crate feature postgres only.

Connect to PostgreSQL with automatic database creation and custom pool size.

See Self::connect_postgres_or_create for details on automatic database creation.

Source

pub async fn connect_sqlite( url: &str, ) -> Result<DatabaseConnection, DatabaseError>

Available on crate feature sqlite only.

Connects to a SQLite database at the given URL.

Source

pub fn from_sqlite_pool(pool: Pool<Sqlite>) -> DatabaseConnection

Available on crate feature sqlite only.

Creates a connection from an existing SQLite pool.

Source

pub async fn connect_mysql( url: &str, ) -> Result<DatabaseConnection, DatabaseError>

Available on crate feature mysql only.

Connects to a MySQL database at the given URL.

Source

pub fn backend(&self) -> Arc<dyn DatabaseBackend>

Performs the backend operation.

Source

pub fn database_type(&self) -> DatabaseType

Get the database type

Source

pub fn is_cockroachdb(&self) -> bool

Returns true when the underlying server is CockroachDB.

CockroachDB is wire-compatible with PostgreSQL and uses the same PostgresBackend, so database_type() returns DatabaseType::Postgres for both. Callers that must dispatch on the server flavour (e.g. the migration-lock path, which cannot use pg_advisory_lock on CockroachDB — see issue #4642) should check this flag first.

The flag is determined at connection time via a single SELECT version() probe and is false for any non-Postgres backend.

Source

pub fn insert(&self, table: impl Into<String>) -> InsertBuilder

Performs the insert operation.

Source

pub fn update(&self, table: impl Into<String>) -> UpdateBuilder

Performs the update operation.

Source

pub fn select(&self) -> SelectBuilder

Performs the select operation.

Source

pub fn delete(&self, table: impl Into<String>) -> DeleteBuilder

Performs the delete operation.

Source

pub fn database_url_from<S>( settings: &S, env_override: Option<&str>, ) -> Result<String, DatabaseError>
where S: HasCoreSettings + ?Sized,

Available on crate feature settings only.

Resolve a database URL from an already-built composed settings value.

This is the preferred entry point for callers that already hold a ProjectSettings (or any type that implements reinhardt_conf::HasCoreSettings). It reads the default entry of CoreSettings::databases and converts it to a URL via DatabaseConfig::to_url.

The optional env_override argument is honored first: if it is Some(url), that URL is returned verbatim. Pass None to skip the override entirely. To opt into the env-var short circuit, bind the result of std::env::var first so the temporary String outlives the borrow:

let database_url_env = std::env::var("DATABASE_URL").ok();
let url = DatabaseConnection::database_url_from(
    settings,
    database_url_env.as_deref(),
)?;
§Errors

Returns a ConnectionError if the core.databases.default entry is missing from the composed settings. DatabaseConfig::to_url itself is infallible, so a successfully resolved default entry always yields Ok(_).

§Example
use reinhardt_db::backends::connection::DatabaseConnection;
let url = DatabaseConnection::database_url_from(settings, None)
    .expect("database url");
Source

pub fn get_database_url_from_env_or_settings( base_dir: Option<PathBuf>, ) -> Result<String, DatabaseError>

👎Deprecated since 0.1.0-rc.29:

use DatabaseConnection::database_url_from with a pre-built ProjectSettings instead

Available on crate feature settings only.

Get database URL from environment variable or settings files

This function first checks the DATABASE_URL environment variable. If not found, it attempts to load database configuration from settings files in the settings/ directory.

§Arguments
  • base_dir - Base directory for the project (defaults to current directory if None)
§Returns

Returns the database URL string, or an error if neither environment variable nor settings configuration is found.

§Deprecated

This function reloads settings/<profile>.toml from disk every time it is invoked, which is wasteful and duplicates settings-loading logic. Use Self::database_url_from with an already-built ProjectSettings instead.

§Example
use reinhardt_db::backends::connection::DatabaseConnection;

let url = DatabaseConnection::get_database_url_from_env_or_settings(None)?;
let conn = DatabaseConnection::connect_sqlite(&url).await?;
Source

pub async fn execute( &self, sql: &str, params: Vec<QueryValue>, ) -> Result<QueryResult, DatabaseError>

Executes the operation.

Source

pub async fn fetch_one( &self, sql: &str, params: Vec<QueryValue>, ) -> Result<Row, DatabaseError>

Fetches one.

Source

pub async fn fetch_all( &self, sql: &str, params: Vec<QueryValue>, ) -> Result<Vec<Row>, DatabaseError>

Fetches all.

Source

pub async fn fetch_optional( &self, sql: &str, params: Vec<QueryValue>, ) -> Result<Option<Row>, DatabaseError>

Fetches optional.

Source

pub async fn begin(&self) -> Result<Box<dyn TransactionExecutor>, DatabaseError>

Begin a database transaction and return a dedicated executor

This method acquires a dedicated database connection and begins a transaction on it. All queries executed through the returned TransactionExecutor are guaranteed to run on the same physical connection, ensuring proper transaction isolation.

§Returns

A boxed TransactionExecutor that holds the dedicated connection and provides methods for executing queries within the transaction.

§Example
use reinhardt_db::backends::connection::DatabaseConnection;

let conn = DatabaseConnection::connect_postgres("postgres://localhost/mydb").await?;
let mut tx = conn.begin().await?;

tx.execute("INSERT INTO users (name) VALUES ($1)", vec!["Alice".into()]).await?;
tx.commit().await?;
Source

pub async fn begin_with_isolation( &self, level: IsolationLevel, ) -> Result<Box<dyn TransactionExecutor>, DatabaseError>

Begin a transaction with a specific isolation level

§Examples
use reinhardt_db::backends::connection::DatabaseConnection;
use reinhardt_db::backends::types::IsolationLevel;

let conn = DatabaseConnection::connect_postgres("postgres://localhost/mydb").await?;
let mut tx = conn.begin_with_isolation(IsolationLevel::Serializable).await?;

tx.execute("INSERT INTO users (name) VALUES ($1)", vec!["Alice".into()]).await?;
tx.commit().await?;
Source

pub fn into_postgres(&self) -> Option<Pool<Postgres>>

Available on crate feature postgres only.

Converts into postgres.

Source

pub fn into_sqlite(&self) -> Option<Pool<Sqlite>>

Available on crate feature sqlite only.

Converts into the underlying SQLite pool, if the backend is SQLite.

Source

pub fn into_mysql(&self) -> Option<Pool<MySql>>

Available on crate feature mysql only.

Converts into the underlying MySQL pool, if the backend is MySQL.

Trait Implementations§

Source§

impl Clone for DatabaseConnection

Source§

fn clone(&self) -> DatabaseConnection

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Injectable for DatabaseConnection

Injectable implementation for DatabaseConnection

DatabaseConnection must be explicitly registered in the DI context using InjectionContextBuilder::singleton(). It cannot be auto-injected because it requires runtime configuration (connection URL, pool settings, etc.).

§Example

use reinhardt_di::{InjectionContext, SingletonScope};
use reinhardt_db::backends::DatabaseConnection;
use std::sync::Arc;

// Create and configure the connection
let db = DatabaseConnection::connect_postgres("postgres://localhost/mydb")
    .await
    .expect("Failed to connect to database");

// Register in DI context
let singleton_scope = Arc::new(SingletonScope::new());
let ctx = InjectionContext::builder(singleton_scope)
    .singleton(db)
    .build();
Source§

fn inject<'life0, 'async_trait>( ctx: &'life0 InjectionContext, ) -> Pin<Box<dyn Future<Output = Result<DatabaseConnection, DiError>> + Send + 'async_trait>>
where 'life0: 'async_trait, DatabaseConnection: 'async_trait,

Creates an instance of this type by resolving dependencies from the injection context.
Source§

fn inject_uncached<'life0, 'async_trait>( ctx: &'life0 InjectionContext, ) -> Pin<Box<dyn Future<Output = Result<DatabaseConnection, DiError>> + Send + 'async_trait>>
where 'life0: 'async_trait, DatabaseConnection: 'async_trait,

Inject without using cache (for cache = false support). Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Any for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Source§

fn type_name(&self) -> &'static str

Source§

impl<T> AnySync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Source§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FromRef<T> for T
where T: Clone,

Source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<T> IntoResult<T> for T

Source§

impl<Unshared, Shared> IntoShared<Shared> for Unshared
where Shared: FromUnshared<Unshared>,

Source§

fn into_shared(self) -> Shared

Creates a shared type from an unshared type.
Source§

impl<L> LayerExt<L> for L

Source§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in Layered.
Source§

impl<T> Pipe for T
where T: ?Sized,

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<S, T> Upcast<T> for S
where T: UpcastFrom<S> + ?Sized, S: ?Sized,

Source§

fn upcast(&self) -> &T
where Self: ErasableGeneric, T: ErasableGeneric<Repr = Self::Repr>,

Perform a zero-cost type-safe upcast to a wider ref type within the Wasm bindgen generics type system. Read more
Source§

fn upcast_into(self) -> T
where Self: Sized + ErasableGeneric, T: ErasableGeneric<Repr = Self::Repr>,

Perform a zero-cost type-safe upcast to a wider type within the Wasm bindgen generics type system. Read more
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more