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 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