From 9b91c356bc717af06bb3fa1727bf0968df98fe8e Mon Sep 17 00:00:00 2001 From: luofucong Date: Fri, 23 Feb 2024 19:11:46 +0800 Subject: [PATCH 1/3] Treat "0" and "1" as valid boolean values. --- src/sql/src/statements.rs | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/src/sql/src/statements.rs b/src/sql/src/statements.rs index eaa6b1480871..4f380580abed 100644 --- a/src/sql/src/statements.rs +++ b/src/sql/src/statements.rs @@ -172,7 +172,15 @@ macro_rules! parse_number_to_value { }.fail() } } - + // It's valid for MySQL JDBC to send "0" and "1" for boolean types, so adapt to that. + ConcreteDataType::Boolean(_) => { + match $n { + "0" => Ok(Value::Boolean(false)), + "1" => Ok(Value::Boolean(true)), + _ => ParseSqlValueSnafu { + msg: format!("Failed to parse number '{}' to boolean column type!", $n)}.fail(), + } + } _ => ParseSqlValueSnafu { msg: format!("Fail to parse number {}, invalid column type: {:?}", $n, $data_type @@ -646,6 +654,12 @@ mod tests { let v = sql_number_to_value(&ConcreteDataType::string_datatype(), "999"); assert!(v.is_err(), "parse value error is: {v:?}"); + + let v = sql_number_to_value(&ConcreteDataType::boolean_datatype(), "0").unwrap(); + assert_eq!(v, Value::Boolean(false)); + let v = sql_number_to_value(&ConcreteDataType::boolean_datatype(), "1").unwrap(); + assert_eq!(v, Value::Boolean(true)); + assert!(sql_number_to_value(&ConcreteDataType::boolean_datatype(), "2").is_err()); } #[test] @@ -671,8 +685,7 @@ mod tests { let sql_val = SqlValue::Number("3.0".to_string(), false); let v = sql_value_to_value("a", &ConcreteDataType::boolean_datatype(), &sql_val, None); assert!(v.is_err()); - assert!(format!("{v:?}") - .contains("Fail to parse number 3.0, invalid column type: Boolean(BooleanType)")); + assert!(format!("{v:?}").contains("Failed to parse number '3.0' to boolean column type!")); let sql_val = SqlValue::Boolean(true); let v = sql_value_to_value("a", &ConcreteDataType::float64_datatype(), &sql_val, None); From cec970d56abfb499607e4348baf0b8fc8c66ed81 Mon Sep 17 00:00:00 2001 From: LFC <990479+MichaelScofield@users.noreply.github.com> Date: Fri, 23 Feb 2024 19:29:06 +0800 Subject: [PATCH 2/3] Update src/sql/src/statements.rs Co-authored-by: tison --- src/sql/src/statements.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/sql/src/statements.rs b/src/sql/src/statements.rs index 4f380580abed..db1036e54538 100644 --- a/src/sql/src/statements.rs +++ b/src/sql/src/statements.rs @@ -178,7 +178,7 @@ macro_rules! parse_number_to_value { "0" => Ok(Value::Boolean(false)), "1" => Ok(Value::Boolean(true)), _ => ParseSqlValueSnafu { - msg: format!("Failed to parse number '{}' to boolean column type!", $n)}.fail(), + msg: format!("Failed to parse number '{}' to boolean column type", $n)}.fail(), } } _ => ParseSqlValueSnafu { From 288c923f520ebbc3f0591a56e7333ad3e7c53e8c Mon Sep 17 00:00:00 2001 From: luofucong Date: Fri, 23 Feb 2024 19:42:39 +0800 Subject: [PATCH 3/3] Fix tests. --- src/sql/src/statements.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/sql/src/statements.rs b/src/sql/src/statements.rs index db1036e54538..a8f38e545d59 100644 --- a/src/sql/src/statements.rs +++ b/src/sql/src/statements.rs @@ -685,7 +685,7 @@ mod tests { let sql_val = SqlValue::Number("3.0".to_string(), false); let v = sql_value_to_value("a", &ConcreteDataType::boolean_datatype(), &sql_val, None); assert!(v.is_err()); - assert!(format!("{v:?}").contains("Failed to parse number '3.0' to boolean column type!")); + assert!(format!("{v:?}").contains("Failed to parse number '3.0' to boolean column type")); let sql_val = SqlValue::Boolean(true); let v = sql_value_to_value("a", &ConcreteDataType::float64_datatype(), &sql_val, None);