Showing results for 
Search instead for 
Did you mean: 
Data Engineering
Join discussions on data engineering best practices, architectures, and optimization strategies within the Databricks Community. Exchange insights and solutions with fellow data engineers.
Showing results for 
Search instead for 
Did you mean: 

Genrated partition column not being used by optimizer


We have created a table using the new generated column feature (

CREATE TABLE ingest.MyEvent(
 data  binary,
 topic string,
 timestamp timestamp,
 date date GENERATED ALWAYS AS (CAST(timestamp AS DATE))
PARTITIONED BY (topic,date)
LOCATION '/mnt/data/myevent'

When running

SELECT * FROM WHERE timestamp > '2021-06-01T12:34'

We were expecting it to push down a filter "date >= '2021-06-01'" so that it can make use of the partitioned column without having to explicit query it. However it does not push down a filter on date, so doesn't benefit from partition filtering

Is it expected that generated columns would be used to optimize queries? Is it possible to make generated columns work the way i'm expecting or am I expecting too much?


Esteemed Contributor III

I think you have to pass a date in your select query instead of a timestamp.

The generated column will indeed derive a data from the timestamp and partition by it.

But the docs state:

When you write to a table with generated columns and you do not explicitly provide values for them, Delta Lake automatically computes the values.

So the date column will be filled while writing. But afaik it is not the case with reading.

So "Select timestamp" will not be translated to "Select date".

When you query on the timestamp column, spark will read the timestamp column, and the table is not partitioned on this.

try this f.e.:
SELECT * FROM WHERE date  = '2021-06-01'

Join 100K+ Data Experts: Register Now & Grow with Us!

Excited to expand your horizons with us? Click here to Register and begin your journey to success!

Already a member? Login and join your local regional user group! If there isn’t one near you, fill out this form and we’ll create one for you to join!