1//! **MySQL** database driver.
2#![deny(clippy::cast_possible_truncation)]
3#![deny(clippy::cast_possible_wrap)]
4#![deny(clippy::cast_sign_loss)]
56#[macro_use]
7extern crate sqlx_core;
89use crate::executor::Executor;
1011pub(crate) use sqlx_core::driver_prelude::*;
1213#[cfg(feature = "any")]
14pub mod any;
1516mod arguments;
17mod collation;
18mod column;
19mod connection;
20mod database;
21mod error;
22mod io;
23mod options;
24mod protocol;
25mod query_result;
26mod row;
27mod statement;
28mod transaction;
29mod type_checking;
30mod type_info;
31pub mod types;
32mod value;
3334#[cfg(feature = "migrate")]
35mod migrate;
3637#[cfg(feature = "migrate")]
38mod testing;
3940pub use arguments::MySqlArguments;
41pub use column::MySqlColumn;
42pub use connection::MySqlConnection;
43pub use database::MySql;
44pub use error::MySqlDatabaseError;
45pub use options::{MySqlConnectOptions, MySqlSslMode};
46pub use query_result::MySqlQueryResult;
47pub use row::MySqlRow;
48pub use statement::MySqlStatement;
49pub use transaction::MySqlTransactionManager;
50pub use type_info::MySqlTypeInfo;
51pub use value::{MySqlValue, MySqlValueFormat, MySqlValueRef};
5253/// An alias for [`Pool`][crate::pool::Pool], specialized for MySQL.
54pub type MySqlPool = crate::pool::Pool<MySql>;
5556/// An alias for [`PoolOptions`][crate::pool::PoolOptions], specialized for MySQL.
57pub type MySqlPoolOptions = crate::pool::PoolOptions<MySql>;
5859/// An alias for [`Executor<'_, Database = MySql>`][Executor].
60pub trait MySqlExecutor<'c>: Executor<'c, Database = MySql> {}
61impl<'c, T: Executor<'c, Database = MySql>> MySqlExecutor<'c> for T {}
6263/// An alias for [`Transaction`][crate::transaction::Transaction], specialized for MySQL.
64pub type MySqlTransaction<'c> = crate::transaction::Transaction<'c, MySql>;
6566// NOTE: required due to the lack of lazy normalization
67impl_into_arguments_for_arguments!(MySqlArguments);
68impl_acquire!(MySql, MySqlConnection);
69impl_column_index_for_row!(MySqlRow);
70impl_column_index_for_statement!(MySqlStatement);
7172// required because some databases have a different handling of NULL
73impl_encode_for_option!(MySql);