tests_fuzz/ir/
create_expr.rs

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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
// Copyright 2023 Greptime Team
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

use std::collections::HashMap;
use std::fmt::Display;

use datatypes::value::Value;
use derive_builder::Builder;
use partition::partition::PartitionDef;
use serde::{Deserialize, Serialize};

use crate::ir::{Column, Ident};

/// The column options
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize, Hash)]
pub enum ColumnOption {
    Null,
    NotNull,
    DefaultValue(Value),
    DefaultFn(String),
    TimeIndex,
    PrimaryKey,
}

impl Display for ColumnOption {
    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
        match self {
            ColumnOption::Null => write!(f, "NULL"),
            ColumnOption::NotNull => write!(f, "NOT NULL"),
            ColumnOption::DefaultFn(s) => write!(f, "DEFAULT {}", s),
            ColumnOption::DefaultValue(s) => match s {
                Value::String(value) => {
                    write!(f, "DEFAULT \'{}\'", value.as_utf8())
                }
                _ => write!(f, "DEFAULT {}", s),
            },
            ColumnOption::TimeIndex => write!(f, "TIME INDEX"),
            ColumnOption::PrimaryKey => write!(f, "PRIMARY KEY"),
        }
    }
}

/// A naive create table expr builder.
#[derive(Debug, Builder, Clone, Serialize, Deserialize)]
pub struct CreateTableExpr {
    #[builder(setter(into))]
    pub table_name: Ident,
    pub columns: Vec<Column>,
    #[builder(default)]
    pub if_not_exists: bool,

    // GreptimeDB specific options
    #[builder(default, setter(into))]
    pub partition: Option<PartitionDef>,
    #[builder(default, setter(into))]
    pub engine: String,
    #[builder(default, setter(into))]
    pub options: HashMap<String, Value>,
    pub primary_keys: Vec<usize>,
}

#[derive(Debug, Builder, Clone, Serialize, Deserialize)]
pub struct CreateDatabaseExpr {
    #[builder(setter(into))]
    pub database_name: Ident,
    #[builder(default)]
    pub if_not_exists: bool,
}