Jovis: A Visualization Tool for PostgreSQL Query Optimizer

Yoojin Choi,Juhee Han,Kyoseung Koo,Bongki Moon
2024-11-22
Abstract:In the world of relational database management, the query optimizer is a critical component that significantly impacts query performance. To address the challenge of optimizing query performance due to the complexity of optimizers -- especially with join operations -- we introduce Jovis. This novel visualization tool provides a window into the often intricate process of query optimization in PostgreSQL, making it more accessible and understandable. PostgreSQL employs two different query optimization strategies: the Dynamic Programming (DP) Optimizer for most scenarios and the Genetic Query Optimizer (GEQO) for more complex queries with numerous joins, both of which are supported in Jovis. Our tool visualizes the optimizer's decision-making process, from evaluating access paths for each relation to determining join orderings, all using data derived from the optimizer's logs. Jovis not only clarifies the query optimization process through visualizations but also serves as an invaluable learning tool for learners and a practical resource for experienced database professionals looking to optimize their query performance or even the query optimizer itself. The source code has been made available at <a class="link-external link-https" href="https://github.com/snu-jovis" rel="external noopener nofollow">this https URL</a>.
Databases,Human-Computer Interaction
What problem does this paper attempt to address?