Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Be one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now

Reply
Debasish_p
Frequent Visitor

Lakehouse Delta table changes are not reflecting in SQL Analytics Endpoint

Hi All,

Column name changes made to delta tables in lakehouse is not reflecting in SQL End point analytics. Has anyone faced similar issues ? Is this a known issue or fabric limitation ? Is schema overwrite the only option ?

 

 

Thanks,

9 REPLIES 9
Shreya_Barhate
Frequent Visitor

When renaming columns in Delta tables within a lakehouse, the changes reflect in SQL Endpoint analytics after a brief delay of 1-2 minutes.

Following steps worked for me, 

 

df = spark.sql("SELECT * FROM lakehouse_name.delta_table_name")
df = df.withColumnRenamed("old_col_name","new_col_name") 
df.write.format("delta").mode("overwrite").option("overwriteSchema", "true").saveAsTable("table_name")

 

NOTE: overwriteschema-overwrites the entire schema and data of the table, mergeschema -merges the new schema with the existing schema, ensuring that all columns (old and new) are included

After these steps, the column name change will be applied, but it may take 1-2 minutes to appear in SQL Endpoint analytics due to metadata refresh.

 

Thanks @Shreya_Barhate . Changes to delta tables are still not reflecting in the SQL Endpoint. I have tried with both Spark 3.4 and Spark 3.5 (public preview) in notebook workspace , still no results in last 1 hour.

If you have already applied column name mapping to your tables, i.e. something like this 

 

ALTER TABLE table_name SET TBLPROPERTIES (

   'delta.columnMapping.mode' = 'name',

   'delta.minReaderVersion' = '2',

   'delta.minWriterVersion' = '5')

 

then I think you will need to create a new table (or a new lakehouse) and don't use the enable column mapping command. Instead, just use overwriteSchema or mergeSchema if you need to edit the schema of your table. You can also use ALTER TABLE ADD COLUMN, but you cannot use other ALTER TABLE commands like RENAME COLUMN or DROP COLUMN.

Thanks @Shreya_Barhate  and @frithjof_v  , I am able to alter column name and data type changes using dataframe in lakehouse rather than ALTER TSQL.

When writing the dataframe with changed columns to a Lakehouse table, are you using .option("overwriteSchema", "true") or .option("mergeSchema", "true")? Or have you found another method?

 

I'm curious about this topic 😃

It's .option("overwriteSchema", "true"). The mergeSchema option will append the renamed column to the end of the schema.

v-huijiey-msft
Community Support
Community Support

Hi @Debasish_p ,

 

Thanks for the reply from @frithjof_v .

 

In addition to using Overwrite, you'll have to check that the following architectures match, and that the saves you've made have not been changed. My test was successful, here are my test steps:

 

Here's my raw tabular data:

vhuijieymsft_0-1722413533433.png

 

When I change the column names and then save the changes using the following statement, I get an architecture mismatch error:

vhuijieymsft_1-1722413533437.png

 

Use the following statement to save your changes without any problems:

df.write.format(“delta”).option(“mergeSchema”, “true”).mode(“overwrite”).save(“Tables/products”)

 

You can also verify that the changes were successful:

df = spark.read.format(“delta”).load(“Tables/products”)
df.show()

 

The last table you see at the SQL endpoint looks like this:

vhuijieymsft_2-1722413573643.png

 

If you have any other questions please feel free to contact me.

 

Best Regards,
Yang
Community Support Team

 

If there is any post helps, then please consider Accept it as the solution  to help the other members find it more quickly.
If I misunderstand your needs or you still have problems on it, please feel free to let us know. Thanks a lot!

Nice, so mergeSchema is also an option, in addition to overwriteSchema 😃

frithjof_v
Community Champion
Community Champion

As far as I know, overwriteSchema is the only option, yes.

 

EDIT: mergeSchema is another option.

Helpful resources

Announcements
Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!

ArunFabCon

Microsoft Fabric Community Conference 2025

Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.

December 2024

A Year in Review - December 2024

Find out what content was popular in the Fabric community during 2024.