 Challenge: Query Optimization
Challenge: Query Optimization
Let's discover two tables: BankAccounts and one additional table named Transactions.
BankAccounts table
Transactions table
Assume we want to retrieve only the account numbers that have performed at least one transaction.
In this task, we have a query that is not optimized. Your task is to rewrite it in a more optimal way.
Here is a list of the main query rewriting techniques to enhance optimization:
- 
Explicitly Specify Columns: Instead of using the asterisk ( *) wildcard, explicitly mention column names in queries for better performance, readability, and maintainability;
- 
Minimize Subqueries: Reduce the use of subqueries to optimize query performance. Consider alternatives like joins or derived tables to avoid complexity and overhead; 
- 
Avoid Repeated IN Operators: Limit the use of the INoperator in queries to prevent performance impact. Instead, consider usingJOINorEXISTSclauses for more efficient execution plans;
- 
Organize Joins Logically: Start SQL joins with the main table and then join with related tables to optimize query organization and database engine optimization; 
- 
Use Restrictive WHERE Conditions: Improve query performance by including restrictive conditions in the WHEREclause to filter rows and enhance execution speed;
- 
Refactor Code into Stored Procedures or Functions: Encapsulate repetitive code segments into stored procedures or user-defined functions for code reusability, modularity, and easier maintenance. These can reduce redundancy and optimize SQL queries. 
Swipe to start coding
Please rewrite the query more optimally. Pay attention to the fact that we need to get only account numbers that have performed at least one transaction (transferred money to another account) sorted in ascending order.
Note
Use
LEFTorINNERjoin type to complete this task.
Solution
Thanks for your feedback!
single
Ask AI
Ask AI
Ask anything or try one of the suggested questions to begin our chat
Awesome!
Completion rate improved to 4.35 Challenge: Query Optimization
Challenge: Query Optimization
Swipe to show menu
Let's discover two tables: BankAccounts and one additional table named Transactions.
BankAccounts table
Transactions table
Assume we want to retrieve only the account numbers that have performed at least one transaction.
In this task, we have a query that is not optimized. Your task is to rewrite it in a more optimal way.
Here is a list of the main query rewriting techniques to enhance optimization:
- 
Explicitly Specify Columns: Instead of using the asterisk ( *) wildcard, explicitly mention column names in queries for better performance, readability, and maintainability;
- 
Minimize Subqueries: Reduce the use of subqueries to optimize query performance. Consider alternatives like joins or derived tables to avoid complexity and overhead; 
- 
Avoid Repeated IN Operators: Limit the use of the INoperator in queries to prevent performance impact. Instead, consider usingJOINorEXISTSclauses for more efficient execution plans;
- 
Organize Joins Logically: Start SQL joins with the main table and then join with related tables to optimize query organization and database engine optimization; 
- 
Use Restrictive WHERE Conditions: Improve query performance by including restrictive conditions in the WHEREclause to filter rows and enhance execution speed;
- 
Refactor Code into Stored Procedures or Functions: Encapsulate repetitive code segments into stored procedures or user-defined functions for code reusability, modularity, and easier maintenance. These can reduce redundancy and optimize SQL queries. 
Swipe to start coding
Please rewrite the query more optimally. Pay attention to the fact that we need to get only account numbers that have performed at least one transaction (transferred money to another account) sorted in ascending order.
Note
Use
LEFTorINNERjoin type to complete this task.
Solution
Thanks for your feedback!
single