Skip to main content

MySqlAsyncConnection

Struct MySqlAsyncConnection 

Source
pub struct MySqlAsyncConnection { /* private fields */ }
Expand description

Async MySQL connection.

This connection uses asupersync’s TCP stream for non-blocking I/O and implements the Connection trait from sqlmodel-core.

Implementations§

Source§

impl MySqlAsyncConnection

Source

pub async fn connect(_cx: &Cx, config: MySqlConfig) -> Outcome<Self, Error>

Establish a new async connection to the MySQL server.

This performs the complete connection handshake asynchronously:

  1. TCP connection
  2. Receive server handshake
  3. Send handshake response with authentication
  4. Handle auth result (possibly auth switch)
Source

pub fn state(&self) -> ConnectionState

Get the current connection state.

Source

pub fn is_ready(&self) -> bool

Check if the connection is ready for queries.

Source

pub fn connection_id(&self) -> u32

Get the connection ID.

Source

pub fn server_version(&self) -> Option<&str>

Get the server version.

Source

pub fn affected_rows(&self) -> u64

Get the number of affected rows from the last statement.

Source

pub fn last_insert_id(&self) -> u64

Get the last insert ID.

Source

pub async fn query_async( &mut self, _cx: &Cx, sql: &str, params: &[Value], ) -> Outcome<Vec<Row>, Error>

Execute a text protocol query asynchronously.

Source

pub async fn execute_async( &mut self, cx: &Cx, sql: &str, params: &[Value], ) -> Outcome<u64, Error>

Execute a statement asynchronously and return affected rows.

This is similar to query_async but returns the number of affected rows instead of the result set. Useful for INSERT, UPDATE, DELETE statements.

Source

pub async fn prepare_async( &mut self, _cx: &Cx, sql: &str, ) -> Outcome<PreparedStatement, Error>

Prepare a statement for later execution using the binary protocol.

This sends COM_STMT_PREPARE to the server and stores the metadata needed for later execution via query_prepared_async or execute_prepared_async.

Source

pub async fn query_prepared_async( &mut self, _cx: &Cx, stmt: &PreparedStatement, params: &[Value], ) -> Outcome<Vec<Row>, Error>

Execute a prepared statement and return result rows (binary protocol).

Source

pub async fn execute_prepared_async( &mut self, cx: &Cx, stmt: &PreparedStatement, params: &[Value], ) -> Outcome<u64, Error>

Execute a prepared statement and return affected row count.

Source

pub async fn close_prepared_async(&mut self, stmt: &PreparedStatement)

Close a prepared statement.

Source

pub async fn ping_async(&mut self, _cx: &Cx) -> Outcome<(), Error>

Ping the server asynchronously.

Source

pub async fn close_async(self, _cx: &Cx) -> Result<(), Error>

Close the connection asynchronously.

Trait Implementations§

Source§

impl Connection for MySqlAsyncConnection

Source§

type Tx<'conn> = MySqlTransaction<'conn>

The transaction type returned by this connection.
Source§

fn query( &self, _cx: &Cx, _sql: &str, _params: &[Value], ) -> impl Future<Output = Outcome<Vec<Row>, Error>> + Send

Execute a query and return all rows.
Source§

fn query_one( &self, _cx: &Cx, _sql: &str, _params: &[Value], ) -> impl Future<Output = Outcome<Option<Row>, Error>> + Send

Execute a query and return the first row, if any.
Source§

fn execute( &self, _cx: &Cx, _sql: &str, _params: &[Value], ) -> impl Future<Output = Outcome<u64, Error>> + Send

Execute a statement (INSERT, UPDATE, DELETE) and return rows affected.
Source§

fn insert( &self, _cx: &Cx, _sql: &str, _params: &[Value], ) -> impl Future<Output = Outcome<i64, Error>> + Send

Execute an INSERT and return the last inserted ID. Read more
Source§

fn batch( &self, _cx: &Cx, _statements: &[(String, Vec<Value>)], ) -> impl Future<Output = Outcome<Vec<u64>, Error>> + Send

Execute multiple statements in a batch. Read more
Source§

fn begin( &self, _cx: &Cx, ) -> impl Future<Output = Outcome<Self::Tx<'_>, Error>> + Send

Begin a transaction with default isolation level (ReadCommitted).
Source§

fn begin_with( &self, _cx: &Cx, _isolation: IsolationLevel, ) -> impl Future<Output = Outcome<Self::Tx<'_>, Error>> + Send

Begin a transaction with a specific isolation level.
Source§

fn prepare( &self, _cx: &Cx, _sql: &str, ) -> impl Future<Output = Outcome<PreparedStatement, Error>> + Send

Prepare a statement for repeated execution. Read more
Source§

fn query_prepared( &self, _cx: &Cx, _stmt: &PreparedStatement, _params: &[Value], ) -> impl Future<Output = Outcome<Vec<Row>, Error>> + Send

Execute a prepared statement and return all rows.
Source§

fn execute_prepared( &self, _cx: &Cx, _stmt: &PreparedStatement, _params: &[Value], ) -> impl Future<Output = Outcome<u64, Error>> + Send

Execute a prepared statement (INSERT, UPDATE, DELETE) and return rows affected.
Source§

fn ping(&self, _cx: &Cx) -> impl Future<Output = Outcome<(), Error>> + Send

Check if the connection is still valid by sending a ping.
Source§

fn close(self, cx: &Cx) -> impl Future<Output = Result<(), Error>> + Send

Close the connection gracefully.
Source§

fn dialect(&self) -> Dialect

Get the SQL dialect for this connection. Read more
Source§

fn is_valid(&self, cx: &Cx) -> impl Future<Output = bool> + Send

Check if the connection is still valid (alias for ping that returns bool).
Source§

impl Debug for MySqlAsyncConnection

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. 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> 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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, _span: NoopSpan) -> Self

Instruments this future with a span (no-op when disabled).
Source§

fn in_current_span(self) -> Self

Instruments this future with the current span (no-op when disabled).
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> Same for T

Source§

type Output = T

Should always be Self
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<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