surql_parser/upstream/sql/statements/
show.rs1use crate::compat::types::PublicDatetime;
2use crate::compat::val::TableName;
3use crate::upstream::fmt::EscapeKwFreeIdent;
4use surrealdb_types::{SqlFormat, ToSql, write_sql};
5#[derive(Clone, Debug, Eq, PartialEq, PartialOrd, Hash)]
6#[cfg_attr(feature = "arbitrary", derive(arbitrary::Arbitrary))]
7pub enum ShowSince {
8 Timestamp(PublicDatetime),
9 Versionstamp(u64),
10}
11#[derive(Clone, Debug, Eq, PartialEq, PartialOrd, Hash)]
13#[cfg_attr(feature = "arbitrary", derive(arbitrary::Arbitrary))]
14pub struct ShowStatement {
15 pub table: Option<String>,
16 pub since: ShowSince,
17 pub limit: Option<u32>,
18}
19impl ToSql for ShowStatement {
20 fn fmt_sql(&self, f: &mut String, fmt: SqlFormat) {
21 write_sql!(f, fmt, "SHOW CHANGES FOR");
22 match self.table {
23 Some(ref v) => write_sql!(f, fmt, " TABLE {}", EscapeKwFreeIdent(v)),
24 None => write_sql!(f, fmt, " DATABASE"),
25 }
26 match self.since {
27 ShowSince::Timestamp(ref v) => write_sql!(f, fmt, " SINCE {}", v),
28 ShowSince::Versionstamp(ref v) => write_sql!(f, fmt, " SINCE {}", v),
29 }
30 if let Some(ref v) = self.limit {
31 write_sql!(f, fmt, " LIMIT {}", v)
32 }
33 }
34}