Skip to content

Commit

Permalink
fix
Browse files Browse the repository at this point in the history
  • Loading branch information
yuhao-su committed Nov 24, 2023
1 parent f707c5f commit 72812a8
Show file tree
Hide file tree
Showing 5 changed files with 58 additions and 33 deletions.
10 changes: 3 additions & 7 deletions src/frontend/src/handler/alter_system.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,9 @@

use pgwire::pg_response::StatementType;
use risingwave_common::error::Result;
use risingwave_sqlparser::ast::{Ident, SetVariableValue, Value};
use risingwave_sqlparser::ast::{Ident, SetVariableValue};

use super::variable::set_var_to_param_str;
use super::{HandlerArgs, RwPgResponse};

// Warn user if barrier_interval_ms is set above 5mins.
Expand All @@ -28,12 +29,7 @@ pub async fn handle_alter_system(
param: Ident,
value: SetVariableValue,
) -> Result<RwPgResponse> {
let value = match value {
SetVariableValue::Literal(Value::DoubleQuotedString(s))
| SetVariableValue::Literal(Value::SingleQuotedString(s)) => Some(s),
SetVariableValue::Default => None,
_ => Some(value.to_string()),
};
let value = set_var_to_param_str(&value);
let params = handler_args
.session
.env()
Expand Down
21 changes: 12 additions & 9 deletions src/frontend/src/handler/variable.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,15 +26,16 @@ use super::RwPgResponse;
use crate::handler::HandlerArgs;
use crate::utils::infer_stmt_row_desc::infer_show_variable;

fn set_var_to_guc_str(value: &SetVariableValue) -> String {
/// convert `SetVariableValue` to string while remove the quotes on literals.
pub(crate) fn set_var_to_param_str(value: &SetVariableValue) -> Option<String> {
match value {
SetVariableValue::Literal(Value::DoubleQuotedString(s))
| SetVariableValue::Literal(Value::SingleQuotedString(s)) => s.clone(),
SetVariableValue::List(list) => list
.iter()
.map(set_var_to_guc_str)
.join(SESSION_CONFIG_LIST_SEP),
_ => value.to_string(),
SetVariableValue::Single(var) => Some(var.to_string_unquoted()),
SetVariableValue::List(list) => Some(
list.iter()
.map(|var| var.to_string_unquoted())
.join(SESSION_CONFIG_LIST_SEP),
),
SetVariableValue::Default => None,
}
}

Expand All @@ -44,7 +45,9 @@ pub fn handle_set(
value: SetVariableValue,
) -> Result<RwPgResponse> {
// Strip double and single quotes
let string_val = set_var_to_guc_str(&value);
let string_val = set_var_to_param_str(&value).ok_or(ErrorCode::InternalError(
"SET TO DEFAULT is not supported yet".to_string(),
))?;

let mut status = ParameterStatus::default();

Expand Down
44 changes: 35 additions & 9 deletions src/sqlparser/src/ast/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2652,24 +2652,50 @@ impl fmt::Display for CreateFunctionUsing {
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
pub enum SetVariableValue {
Ident(Ident),
Literal(Value),
List(Vec<SetVariableValue>),
Single(SetVariableValueSingle),
List(Vec<SetVariableValueSingle>),
Default,
}

impl From<SetVariableValueSingle> for SetVariableValue {
fn from(value: SetVariableValueSingle) -> Self {
SetVariableValue::Single(value)
}
}

impl fmt::Display for SetVariableValue {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
use SetVariableValue::*;
match self {
Single(val) => write!(f, "{}", val),
List(list) => write!(f, "{}", display_comma_separated(list),),
Default => write!(f, "DEFAULT"),
}
}
}

#[derive(Debug, Clone, PartialEq, Eq, Hash)]
pub enum SetVariableValueSingle {
Ident(Ident),
Literal(Value),
}

impl SetVariableValueSingle {
pub fn to_string_unquoted(&self) -> String {
match self {
Self::Literal(Value::SingleQuotedString(s))
| Self::Literal(Value::DoubleQuotedString(s)) => s.clone(),
_ => self.to_string(),
}
}
}

impl fmt::Display for SetVariableValueSingle {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
use SetVariableValueSingle::*;
match self {
Ident(ident) => write!(f, "{}", ident),
Literal(literal) => write!(f, "{}", literal),
List(list) => write!(
f,
"{}",
list.iter().map(|value| value.to_string()).join(", ")
),
Default => write!(f, "DEFAULT"),
}
}
}
Expand Down
8 changes: 4 additions & 4 deletions src/sqlparser/src/parser.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3228,12 +3228,12 @@ impl Parser {
loop {
let token = self.peek_token();
let value = match (self.parse_value(), token.token) {
(Ok(value), _) => SetVariableValue::Literal(value),
(Ok(value), _) => SetVariableValueSingle::Literal(value),
(Err(_), Token::Word(w)) => {
if w.keyword == Keyword::DEFAULT {
SetVariableValue::Default
return Ok(SetVariableValue::Default);
} else {
SetVariableValue::Ident(w.to_ident()?)
SetVariableValueSingle::Ident(w.to_ident()?)
}
}
(Err(_), unexpected) => {
Expand All @@ -3246,7 +3246,7 @@ impl Parser {
}
}
if values.len() == 1 {
Ok(values[0].clone())
Ok(SetVariableValue::Single(values[0].clone()))
} else {
Ok(SetVariableValue::List(values))
}
Expand Down
8 changes: 4 additions & 4 deletions src/sqlparser/tests/sqlparser_postgres.rs
Original file line number Diff line number Diff line change
Expand Up @@ -392,7 +392,7 @@ fn parse_set() {
Statement::SetVariable {
local: false,
variable: "a".into(),
value: SetVariableValue::Ident("b".into()),
value: SetVariableValueSingle::Ident("b".into()).into(),
}
);

Expand All @@ -402,7 +402,7 @@ fn parse_set() {
Statement::SetVariable {
local: false,
variable: "a".into(),
value: SetVariableValue::Literal(Value::SingleQuotedString("b".into())),
value: SetVariableValueSingle::Literal(Value::SingleQuotedString("b".into())).into(),
}
);

Expand All @@ -412,7 +412,7 @@ fn parse_set() {
Statement::SetVariable {
local: false,
variable: "a".into(),
value: SetVariableValue::Literal(number("0")),
value: SetVariableValueSingle::Literal(number("0")).into(),
}
);

Expand All @@ -432,7 +432,7 @@ fn parse_set() {
Statement::SetVariable {
local: true,
variable: "a".into(),
value: SetVariableValue::Ident("b".into()),
value: SetVariableValueSingle::Ident("b".into()).into(),
}
);

Expand Down

0 comments on commit 72812a8

Please sign in to comment.