sea_schema/mysql/query/
version.rs1use 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}