Skip to content

Commit

Permalink
chore: generated expression parsing improvement, support on first wri…
Browse files Browse the repository at this point in the history
…te/create
  • Loading branch information
ion-elgreco committed Jan 13, 2025
1 parent 1ee0441 commit 571f101
Show file tree
Hide file tree
Showing 3 changed files with 40 additions and 4 deletions.
11 changes: 11 additions & 0 deletions crates/core/src/delta_datafusion/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1198,6 +1198,17 @@ impl DeltaDataChecker {
}
}

/// Create a new DeltaDataChecker with a specified set of generated columns
pub fn new_with_generated_columns(generated_columns: Vec<GeneratedColumn>) -> Self {
Self {
constraints: vec![],
invariants: vec![],
generated_columns: generated_columns,
non_nullable_columns: vec![],
ctx: DeltaSessionContext::default().into(),
}
}

/// Specify the Datafusion context
pub fn with_session_context(mut self, context: SessionContext) -> Self {
self.ctx = context;
Expand Down
27 changes: 24 additions & 3 deletions crates/core/src/kernel/models/schema.rs
Original file line number Diff line number Diff line change
Expand Up @@ -75,11 +75,32 @@ impl StructTypeExt for StructType {
line: generated_col_string.to_string(),
}
})?;
if let Value::String(sql) = json {
generated_cols.push(GeneratedColumn::new(&field_path, &sql, field.data_type()));
}
match json {
Value::String(sql) => generated_cols.push(GeneratedColumn::new(
&field_path,
&sql,
field.data_type(),
)),
Value::Number(sql) => generated_cols.push(GeneratedColumn::new(
&field_path,
&format!("{}", sql),
field.data_type(),
)),
Value::Bool(sql) => generated_cols.push(GeneratedColumn::new(
&field_path,
&format!("{}", sql),
field.data_type(),
)),
Value::Array(sql) => generated_cols.push(GeneratedColumn::new(
&field_path,
&format!("{:?}", sql),
field.data_type(),
)),
_ => (), // Other types not sure what to do then
};
}
}
dbg!(generated_cols.clone());
Ok(generated_cols)
}

Expand Down
6 changes: 5 additions & 1 deletion crates/core/src/operations/write.rs
Original file line number Diff line number Diff line change
Expand Up @@ -439,7 +439,11 @@ async fn write_execution_plan_with_predicate(
let checker = if let Some(snapshot) = snapshot {
DeltaDataChecker::new(snapshot)
} else {
DeltaDataChecker::empty()
debug!("Using plan schema to derive generated columns, since no shapshot was provided. Implies first write.");
let delta_schema: StructType = schema.as_ref().try_into()?;
DeltaDataChecker::new_with_generated_columns(
delta_schema.get_generated_columns().unwrap_or_default(),
)
};
let checker = match predicate {
Some(pred) => {
Expand Down

0 comments on commit 571f101

Please sign in to comment.