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
#[cfg(feature = "with-serde")]
use serde::{Deserialize, Serialize};
use super::{NotNull, Type};
#[derive(Clone, Debug, PartialEq)]
#[cfg_attr(feature = "with-serde", derive(Serialize, Deserialize))]
pub struct ColumnInfo {
/// The name of the column
pub name: String,
/// The type of the column with any additional definitions such as the precision or the character
/// set
pub col_type: ColumnType,
/// The default value experssion for this column, if any
pub default: Option<ColumnExpression>,
/// The generation expression for this column, if it is a generated colum
pub generated: Option<ColumnExpression>,
pub not_null: Option<NotNull>,
pub is_identity: bool,
// TODO:
// /// A constraint that ensures the value of a column is unique among all other rows in the table
// pub unique: Option<Vec<constraints::Unique>>,
// /// A constraint that states that the column is the unique identifier or part of the unique
// /// identifier of each row for this table
// pub primary_key: Option<constraints::PrimaryKey>,
// /// A constraint that ensures that the value of this column must refer to a unique key in another
// /// table
// pub references: Option<constraints::References>,
// FIXME: Include if there's a convenient way to look for this
// /// Comments on the column made by the user
// pub comment: String,
}
pub type ColumnType = Type;
#[derive(Clone, Debug, PartialEq)]
#[cfg_attr(feature = "with-serde", derive(Serialize, Deserialize))]
pub struct ColumnExpression(pub String);
impl ColumnExpression {
pub fn from_option_string(maybe_string: Option<String>) -> Option<ColumnExpression> {
maybe_string.map(ColumnExpression)
}
}