Trait ormlite_core::model::Model

source ·
pub trait Model<DB>
where DB: Database, Self: Sized + TableMeta,
{ type ModelBuilder<'a>: ModelBuilder<'a, DB> where Self: 'a; // Required methods fn insert<'a, A>(self, conn: A) -> Insertion<'a, A, Self, DB> where A: 'a + Send + Acquire<'a, Database = DB>, Self: Send; fn update_all_fields<'e, E>(self, db: E) -> BoxFuture<'e, Result<Self>> where E: 'e + Send + Executor<'e, Database = DB>; fn delete<'e, E>(self, db: E) -> BoxFuture<'e, Result<()>> where E: 'e + Executor<'e, Database = DB>; fn fetch_one<'e, 'a, Arg, E>(id: Arg, db: E) -> BoxFuture<'e, Result<Self>> where E: 'e + Executor<'e, Database = DB>, Arg: 'a + Send + Encode<'a, DB> + Type<DB>, 'a: 'e; fn query(query: &str) -> QueryAs<'_, DB, Self, DB::Arguments<'_>>; fn select<'args>() -> SelectQueryBuilder<'args, DB, Self>; fn update_partial(&self) -> Self::ModelBuilder<'_>; fn builder() -> Self::ModelBuilder<'static>; }
Expand description

The core trait. a struct that implements Model can also implement HasModelBuilder, (and is required to implement Insertable)

Required Associated Types§

source

type ModelBuilder<'a>: ModelBuilder<'a, DB> where Self: 'a

Required Methods§

source

fn insert<'a, A>(self, conn: A) -> Insertion<'a, A, Self, DB>
where A: 'a + Send + Acquire<'a, Database = DB>, Self: Send,

Insert the model into the database.

source

fn update_all_fields<'e, E>(self, db: E) -> BoxFuture<'e, Result<Self>>
where E: 'e + Send + Executor<'e, Database = DB>,

Model objects can’t track what fields are updated, so this method will update all fields. If you want to update only some fields, use update_partial instead.

source

fn delete<'e, E>(self, db: E) -> BoxFuture<'e, Result<()>>
where E: 'e + Executor<'e, Database = DB>,

source

fn fetch_one<'e, 'a, Arg, E>(id: Arg, db: E) -> BoxFuture<'e, Result<Self>>
where E: 'e + Executor<'e, Database = DB>, Arg: 'a + Send + Encode<'a, DB> + Type<DB>, 'a: 'e,

Get by primary key.

source

fn query(query: &str) -> QueryAs<'_, DB, Self, DB::Arguments<'_>>

If query building isn’t meeting your needs, use this method to query the table using raw SQL.

source

fn select<'args>() -> SelectQueryBuilder<'args, DB, Self>

Create a SelectQueryBuilder to build a query.

source

fn update_partial(&self) -> Self::ModelBuilder<'_>

Create a builder-pattern object to update one or more columns. You can also use update_all_fields to update all columns.

source

fn builder() -> Self::ModelBuilder<'static>

Object Safety§

This trait is not object safe.

Implementors§