sea_schema/mysql/query/
version.rs

1use super::SchemaQueryBuilder;
2use crate::sqlx_types::mysql::MySqlRow;
3use sea_query::{Func, Query, SelectStatement};
4
5#[derive(sea_query::Iden)]
6enum MysqlFunc {
7    Version,
8}
9
10#[derive(Debug, Default)]
11pub struct VersionQueryResult {
12    pub version: String,
13}
14
15impl SchemaQueryBuilder {
16    pub fn query_version(&self) -> SelectStatement {
17        Query::select().expr(Func::cust(MysqlFunc::Version)).take()
18    }
19}
20
21#[cfg(feature = "sqlx-mysql")]
22impl From<&MySqlRow> for VersionQueryResult {
23    fn from(row: &MySqlRow) -> Self {
24        use crate::mysql::discovery::GetMySqlValue;
25        Self {
26            version: row.get_string(0),
27        }
28    }
29}
30
31#[cfg(not(feature = "sqlx-mysql"))]
32impl From<&MySqlRow> for VersionQueryResult {
33    fn from(_: &MySqlRow) -> Self {
34        Self::default()
35    }
36}