Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Execute adding column comments/constraints as a single query #845

Open
jsingh-cw opened this issue Nov 18, 2024 · 2 comments
Open

Execute adding column comments/constraints as a single query #845

jsingh-cw opened this issue Nov 18, 2024 · 2 comments
Labels
enhancement New feature or request

Comments

@jsingh-cw
Copy link

Currently, if I provide column comments or NOT NULL constraints for 100 columns in a model, dbt-databricks adapter ends up running 200 separate queries resulting in significantly long total model run time. Ideally, all comments should be added via single ALTER query and constraints should be added via second ALTER query.

This will benefit model run time.

Please see attached log to see how individual SQL queries added to the overall model runtime. Table creation/data load takes less than 30 seconds but column comments and NOT NULL constraints are added to one column per SQL query and takes ~7 mins to complete.

debug_run_86601.log

image

@jsingh-cw jsingh-cw added the enhancement New feature or request label Nov 18, 2024
@benc-db
Copy link
Collaborator

benc-db commented Nov 19, 2024

I'm working on this as we speak. There is no bulk alter for column comments, but I'm reshaping materializations to set comments at create time. This means separating create and insert of data (because you can't set comments with 'create table as select' :), but given how much users have complained about comment performance, I expect it will be a net win.

@jeremyyeo
Copy link

Fwiw - users who find their say hourly runs doing persist docs on columns taking too long (cause every single run has those alter table ... change column ddls) - can try to move to perhaps a once daily / once weekly run-op that manually adds those comments. Something like https://github.com/jeremyyeo/the-hitchhikers-guide-to-dbt/tree/main/manually-persisting-docs

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

3 participants