1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
use sea_query::{Condition, Expr, Query, SelectStatement, SimpleExpr};

use super::query::{InformationSchema as Schema, StatisticsFields, TablesFields};
use super::MySql;
use crate::probe::{Has, SchemaProbe};

impl SchemaProbe for MySql {
    fn get_current_schema() -> SimpleExpr {
        Expr::cust("DATABASE()")
    }

    fn query_tables() -> SelectStatement {
        Query::select()
            .expr_as(Expr::col(TablesFields::TableName), TablesFields::TableName)
            .from((Schema::Schema, Schema::Tables))
            .cond_where(
                Condition::all().add(
                    Expr::expr(Self::get_current_schema())
                        .equals((Schema::Tables, TablesFields::TableSchema)),
                ),
            )
            .take()
    }

    fn has_index<T, C>(table: T, index: C) -> SelectStatement
    where
        T: AsRef<str>,
        C: AsRef<str>,
    {
        Query::select()
            .expr_as(Expr::cust("COUNT(*) > 0"), Has::Index)
            .from((Schema::Schema, Schema::Statistics))
            .cond_where(
                Condition::all()
                    .add(Expr::col(StatisticsFields::TableSchema).eq(Self::get_current_schema()))
                    .add(Expr::col(StatisticsFields::TableName).eq(table.as_ref()))
                    .add(Expr::col(StatisticsFields::IndexName).eq(index.as_ref())),
            )
            .take()
    }
}