Most database vendors provide support (in Data Manipulation Language (DML) syntax) for query processing against structured and/or unstructured data. Large-scale commercial databases can process queries that can take a significant amount of time to complete given the complexities of the queries, resources available to the databases, memory and processing loads of the resources, and the data storage sizes of the databases.
As a result, database architectures include query parsers and query optimizers that optimally assemble a user-defined query from the DML syntax into low-level constructs forming a query execution plan that can best utilize the hardware and software resources of the database to efficiently execute the user-defined query in an acceptable and timely fashion.
The parser can deconstruct components of a single query provided in the DML syntax into multiple equivalent versions of the query for processing by the optimizer. Similarly, the optimizer can produce multiple query execution plans for a given parsed query provided by the parser. Each alternative query execution plan is equivalent (will produce the same query results) to the other produced query execution plans for the parsed query. Each different version produced by the parser for input to the optimizer and each different execution plan produced by the optimizer may focus on optimizing different aspects of the query, such that selection of the best version is dependent on a multiplicity of factors and/or a state of the database.
The parser and the optimizer also utilize hardware and software resources of the database. Consequently, query scheduling, query optimization, and query caching are all activities that are affected by the amount of time that it takes the parser to parse the query, the amount of time that it takes the optimizer to optimize the query, and the amount of time that it takes to process the execution plan for the optimized query.
Sometimes, the query parsing time and/or the query optimization time may exceed the actual query execution time for the plan produced by the optimizer. As such, there is a point of diminishing returns in which it becomes non-optimal to attempt to continue optimizing a given query.
Another consideration with any given query's parsing, optimization, and execution is any Service-Level Agreement (SLA) in which a given user is assured of a predetermined level of responsiveness from the database for query execution. SLAs may apply to a given customer of the database, a given user of the customer, and/or a given query or a given type of query.
In various embodiments, a system, methods, and a database for predictive query parsing time and optimization are provided.
In one embodiment, a method for predictive query parsing time and optimization is provided. A query is parsed for features present in the query. The features are inputted as input to a trained machine-learning algorithm. An estimated amount of time necessary for a query parser to fully parse the query into database constructs is received as output from the trained machine-learning algorithm. The estimated amount of time and the database constructs are processed for producing a query execution plan for the query that accounts for the estimated amount of time in combination with the database constructs.
As used herein, the terms and phrases “database,” and “data warehouse” may be used interchangeably and synonymously. That is, a data warehouse may be viewed as a collection of databases or a collection of data from diverse and different data sources that provides a centralized access and federated view of the data from the different data sources through the data warehouse (may be referred to as just“warehouse”).
Predicting query parsing time and query execution time in a database is useful for many database operations, such as and by way of example only, query scheduling, query caching, a query optimizations performed by a query optimizer, and SLA compliance for contractual obligations with customers of the database.
However, there are tradeoffs that must be accounted for when knowing the query parsing and execution time of a query before query optimization. The query optimizer can make different optimizations based on the parsing and execution times of a query.
For example, if a database (the parser and the optimizer) spends more time parsing and/or optimizing a query than it takes for the query to actually execute, the optimizer (if it had such knowledge before optimization) can reduce parsing time or some optimization processing without affecting the execution plan for the query.
Conversely, the optimizer may spend more time optimizing a given query if it knows that the execution time for the query is high in an effort to reduce the execution time of the query.
Additionally, prediction of the parsing and execution time of a query can help predict if a query is in compliance with a SLA even before the query parsing has started. Such knowledge, helps to tune the database parameters automatically or optimize the query differently (such as increase look ahead processing to produce a better execution plan or to make more use of query execution optimizations, such as in-memory optimizations or Graphics Processing Unit (GPU) accelerators for some of the query operations).
The goal in the industry is to create autonomous workload management capabilities for database systems. To this end, an accurate estimation of query parsing time and query elapsed execution time is of import. The sooner these time estimations are known for a given query in a given DML (such as Structured Query Language (SQL) and others), the more focused and meaningful the query optimizations can be.
Conventionally, the query execution time is predicted after the query optimizer produces the query execution plan for the query, such practice is only useful in revising the query and producing a different optimization. This iteration with revised optimizations is also time consuming and expends resources (hardware and software) of the database.
Moreover, various embodiments depicted herein are implemented as one or more software modules, which are programmed within memory and/or non-transitory computer-readable storage media as executable instructions that are executed on one or more hardware processing devices (having memory, storage, network connections, one or more processors, etc.).
The system 100 includes a DML query 101, a parser time predictor 102, a query parser 103, a query optimizer 104, a plurality of Access Module Processors (AMPs) 105, and database statistics 106.
Query parsing time is a function of many SQL-supported operations (SQL is one type of DML), such as projections, number of database tables, joins present in the query 101, presence of different SQL clauses (such as GROUP BY, ORDER BY, etc.), and other supported operations. Query parsing time is also dependent on the number of views, nested views, join indexes, and other indexes present on the tables and referenced in the query 101 as the time is spent on processing different optimizations and resolutions of these types of database objects (constructs).
The following is an example list of SQL features that are considered as input to a machine-learning and machine-trained parser time predictor 102. The predictor 102 outputs an estimated parsing time for a given query 101 based on the presence of or lack of these SQL features or outputs a classification assignment for the predictive parsing time for the query 101.
In an embodiment, the predictor 102 also uses as input features of the query 101 for the number of views (including complexity of WHERE clauses in the query 101), the number of nested views, and the number of join indexes used by the query 101.
As used herein, “features” or“factors” refer to the above-mentioned constructs and operations defined in a given query 101 using a query editor or query interface to the database.
Initially, the predictor 102 is trained on queries 101 utilizing as input the above-noted features present in the syntax and semantics of queries 101 and the actual parsing execution times needed by the parser 103 as obtained from the database statistics 106 once the queries 101 are fully parsed by the parser 103. The predictor 102 may be a neural network algorithm that weights the various features/factors provided as input from the queries 101 in order to calculate the actual known query parsing times based the features/factors. Training can also be iterative, such as given a query 101 with its known features and an expected query parsing time, the predictor 102 is instructed to keep iteratively processing the features until it has an algorithm that produces the expected query parsing time from the query 101.
The query parser 103 is modified or a separate software module (not shown in the
The preprocessed initial features for the query 101 and a query identifier are provided as input to the trained predictor 102. The output from the trained predictor 102 is the predictive parsing execution time for the query 101 or a classification for the estimated parsing execution time (classified into buckets, such as classification identifier number 1 between 0-1 seconds, classification identifier number 2 between 1-5 seconds, classification identifier number 3 between 5-10 seconds, etc.).
It is to be noted the time estimation for the parsing required by the parser 103 for a given query 101 can be based on actual Central Processing Unit (CPU) time and/or elapsed time (when received by the parser 103 and when completed by the parser 103). This approach with the predictor 102 can also be used for resource consumption used by the CPU and/or with respect Input/Output (I/O).
The predictor 102 can utilize a regression approach, such that the exact parse time for the query 101 as needed by the parser 103 to parse the query 101 is provided as output. Alternatively, the predictor 102 can utilize a classification approach (as discussed above), such that an estimated parse time for the query 101 as needed by the parser 103 to parse the query 101 is provided as a classification identifier, where the classification identifier is a range of estimated parsing execution time.
Additionally, the processing phase at which the predictor 102 is processed for a submitted query 101 can vary.
The predictor 102 is now discussed within the context of an example trial test. Approximately, 111,000 queries 101 were processed. 70% of the 111,000 queries 101 were used to train the predictor 102 and 30% of the 111,000 queries 101 were used as testing on the trained predictor 102.
In the regression-based version of the predictor 102, the predictor 102 was processed to provide an exact value of time required to parse a given query 101 provided as input to the predictor 102. The features present in the query 101 was extracted along with a frequency number that identified the frequency with which each feature occurred in the query 101. The features were normalized to a unit Gaussian. The regression-version of the predictor 102 was trained on the normalized features extracted from the queries 101 along with expected parsing times that was desired as output from the predictor 102. The accuracy of the results were measured as a Mean Squared Error (MSE) and R2 coefficient.
A Support Vector Machine (SVM) regressor, an Ensemble Tree regressor, and a Neural Network (NN) regressor were processed for the machine-learning algorithm of the predictor 102. Results indicated that the NN regressor provided the best accuracy and on the test set (30% of 111,000 queries), the NN regressor implementation of the predictor 102 provided a MSE of 0.30 and R2 value of 0.873. The NN regressor implementation training curves are shown in the
In a classification-based version of the predictor 102, the same 111,000 queries 101 were processed. The trained output for the parsing time of the parser was confined to six classification buckets for the parsing time as follows:
A Multi-Layered Perceptron (MLP) algorithm with 3 layers was used for the predictor 102. There was a single hidden layer with 128 hidden units having approximately 5,200 parameters. A Tan h function was used as the activation function and the learning rate was optimized using an Adam optimizer. Training and validation of the NN used for classification output provided by the predictor 102 for the test is shown in the
Multiple NNs were tested during the trial with different configurations (layers, weights, etc.) to obtain a highest per-class accuracy model for the classification-based predictor 102. Three models were compared: model M1 having approximately 5,200 parameters, model M2 having approximately 11,300 parameters, and model M3 having approximately 14,400 parameters. The models were trained on batch sizes of 256. The M1 demonstrated superior performance on validation and on the test set. Comparisons of per-class accuracy of the three models M1-M3 are shown in the
The overall accuracy of the results was approximately 99.5%. Per class accuracy was 99.9%, 66.12%, 40.6%, 66.31%, 45%, and 72%.
The confusion matrix, which shows the intra-class confusion is as follows:
The output from the predictor 102 is provided to a modified and enhanced version of the optimizer 104 as input (the optimizer 104 is enhanced to receive as input the expected, estimated, or predicted parsing time for the parser 103). The optimizer 104 may also take as input parameters or metrics associated with a SLA for the query 101. The optimizer 104 is configured to use the predicted parsing time provided by the predictor 102 and any SLA metrics, to identify an amount of optimization and the types of optimization to focus on when the query execution plan is produced by the optimizer 104 for the query 101 (some specific types of optimizations to focus on were discussed above). This provides a directed and focused approach to the optimization of the query 101 and allows for a more autonomous workload management database. This approach is resource (hardware and software) efficient and intelligent because the optimizer knows based on the predictive parsing time, the complexities of the query 101 and based on the parsed constructs (features) can focus on specific optimizations to improve query execution times.
Once the execution plan is produced by the optimizer 104, the query 101 is scheduled for execution by the AMPs 105 within the database. The execution plan was tailored and focused by the optimizer 104 based on the parsing time prediction (exact time or classification-based) provided as input by the predictor 102. The execution plan identifies segments of the query 101 along with resources needed (hardware and software) for each AMP 105.
As used herein, “query optimization” refers to directed and focused query execution plan production by the optimizer 104 based on a predicted parsing time for a parser 103 as provided by the machine-learning and machine-trained predictor 104.
The above-discussed embodiments and other embodiments are now discussed with reference to the
These and other embodiments are now discussed with the
In an embodiment, the query parsing time predictor is implemented within a data warehouse across one or more physical devices or nodes (computing devices) for execution over a network connection.
In an embodiment, the query parsing time predictor includes the predictor 102, the parser 103, and/or the optimizer 104. That is, the query parsing time predictor performs, inter alia, the processing as discussed above with the
At 210, the query parsing time predictor parses text of a query (submitted in a DML format, such as SQL format) for features present in the query text. In an embodiment, the features are any of the above-noted features discussed with reference to the
In an embodiment, at 211, the query parsing time predictor processes as a preprocessor or preprocessing step of a query parser of a database or database system before the query parser fully parses the query into database constructs (data structures and operations recognized by the database for the DML format of the query).
In an embodiment, at 212, the query parsing time predictor parses the features as reserved syntax that identifies database operations for a given DML format of the query.
In an embodiment of 212, at 213, the query parsing time predictor identifies the given DML format as a SQL format.
In an embodiment of 213, at 214, the query parsing time predictor identifies semantics present within the query representing database views, nested views, and join indexes.
In an embodiment of 214, at 215, the query parsing time predictor records, with each feature, a frequency with which each semantic appears within the query.
At 220, the query parsing time predictor inputs the features as an input to a trained machine-learning algorithm.
In an embodiment, the trained machine-learning algorithm is the predictor 102.
At 230, the query parsing time predictor receives as an output from the trained machine-learning algorithm an estimated amount of time predicted as being necessary for a query parser to fully and completely parse the query into database constructs recognized by and processed by the database and the query optimizer.
In an embodiment, at 231, the query parsing time predictor receives the output as a classification identifier for a classification time range that the estimated amount of time falls within.
In an embodiment, at 232, the query parsing time predictor receives the estimated amount of time as an actual predicted time for parsing the query by the query parser.
At 240, the query parsing time predictor processes the estimated amount of time and the database constructions and produces a query execution plan that accounts for the estimated amount of time in combination with the database constructs. That is, the typical optimization performed by a conventional optimizer is modified and enhanced to use the estimated amount of time as a factor when optimizing the query in the query execution plan.
According to an embodiment, at 241, the query parsing time predictor passes the query to the query parser and passes the estimated amount of time to a query optimizer of the database system for producing the query execution plan.
In an embodiment, at 250, the query parsing time predictor schedules the query for execution at a scheduled time and processes the query execution plan for the query against database tables of the database at the scheduled time.
In an embodiment, at 260, the query parsing time predictor obtains an actual parsing execution time for parsing the query by the query parser. That is, once the query parser has completely parsed the query into the database constructs, the actual execution time or elapsed execution time required by the query parser is known. The actual time may be housed in database statistics 106 for retrieval within the database system. The query parsing time predictor provides the actual parsing execution time with a query identifier that uniquely identifies the query back to the trained machine-learning algorithm for dynamical learning and adjustment by the trained machine-learning algorithm based on the actual parsing execution time required by the query parser. This perm its learning and adjustments of the weights and factors used by the trained machine-learning algorithm to ensure that the accuracy rate of the trained machine-learning algorithm is continually and dynamically improving over time.
The machine-learning query parsing time predictor presents another and in some ways enhanced perspective of the processing discussed above with the
In an embodiment, the machine-learning query parsing time predictor is all or some combination of: the predictor 102, the parser 103, the optimizer 104, and/or the method 200.
At 310, the machine-learning query parsing time predictor iteratively trains a machine learning algorithm with features extracted from training queries and with the actual known parsing execution times required by a query parser when parsing the training queries into database constructions for further processing by a query optimizer. The machine-learning query parsing time predictor produces a trained machine-learning algorithm. The trained machine-learning algorithm when subsequently provided a candidate query with candidate features produces as output a predicted parsing execution time predicted for the query parser based on the candidate query.
In an embodiment, at 311, the machine-learning query parsing time predictor trains the machine-learning algorithm as a regression-based neural network (such as the regression-based neural network discussed above with the
In an embodiment, at 312, the machine-learning query parsing time predictor trains the machine-learning algorithm as a classification-based neural network (such as the classification-based neural network discussed above with the
In an embodiment, the machine-learning query parsing time predictor processes a preprocessor parser configured to parse the features rapidly from the training queries automatically and provide as input to the machine-learning algorithm during the training at 310.
In an embodiment of 313, the machine-learning query parsing time predictor provides the preprocessor as a front-end process or processing step to the query processor.
At 320, the machine-learning query parsing time predictor extracts specific features from a submitted production database query for execution against a database.
At 330, the machine-learning query parsing time predictor inputs the specific features into the trained machine-learning algorithm produced at 310.
At 340, the machine-learning query parsing time predictor receives a specific predicted parsing execution time back from the trained machine-learning algorithm.
At 350, the machine-learning query parsing time predictor produces a query execution plan for executing the submitted query based at least in part on the specific predicted parsing execution time received at 340. That is, the specific predicated parsing execution time drives (as at least one factor from a plurality of factors) the decisions made by the query optimizer when producing the query execution plan for the submitted query. The query execution plan is tailored at least partially or customized for the specific predicted parsing execution time.
In an embodiment, at 351, the machine-learning query parsing time predictor provides the submitted query to the query parser, which produces database constructs from the submitted query, and the machine-learning query parsing time predictor provides the specific predicted parsing execution time to a query optimizer. The query optimizer producing the query execution time based at least in part or using as one factor, the specific predicted parsing execution time.
In an embodiment of 351, at 352, the query optimizer adjusts the query execution plan based on a SLA associated with the submitted query in view of the specific predicted parsing execution time. That is, the specific predicated parsing execution time may indicate that the submitted query is within a range for response times that is problematic for the SLA, and in response thereto takes different or more focused optimization steps when producing the query execution plan to adjust what would normally be produced by the query optimizer.
In an embodiment, at 360, the query optimizer identifies an actual query execution time for executing the query execution plan and when the specific predicted parsing execution time and/or the actual query execution time exceeds a threshold amount of time (for example, 1 second), the query optimizer caches the query execution time in memory for subsequent execution of the query or similar queries.
In an embodiment, at 370, the query optimizer identifies resources required by the query execution plan and based on a the specific predicted parsing execution time (or an actual parsing execution time for the query) and a total number of the resources, the query optimizer performs processing for one or more of: scheduling the submitted query at a time that will be ensured to satisfy a SLA associated with the submitted query, dynamically increase priorities for the resources to ensure satisfaction of the SLA, and dynamically increase the total number of resources used in the query execution plan to satisfy the SLA.
The database 400 implements, inter alia, the processing discussed above with the
The database 400 includes at least one hardware processor 401 and a non-transitory computer-readable storage medium having executable instructions representing a query parsing time predictor 402, a query parser 403, and a query optimizer 404.
In an embodiment, the predictor 402 is all of some combination of: the predictor 102, the method 200, and/or the method 300.
In an embodiment, the predictor 402 and the parser 403 are one software module with the predictor 402 being a front-end preprocessor to the parser 403.
The predictor 402 is configured to execute on the at least one hardware processor 401 from the non-transitory computer-readable storage medium to perform processing to: extract features from a query, process the features to provide a predicted parsing execution time for the query parser 403 to parse the query into database constructs, provide the query to the query parser 403, and provide the predicted parsing execution time to the query optimizer 404.
In an embodiment, the predictor 402 is further configured to pass the features as input to a trained regression-based neural network or a trained classification-based neural network and receive the predicted parsing execution time as output from the trained regression-based neural network of the trained classification-based neural network.
The parser 403 is configured to execute on the at least one hardware processor 401 from the non-transitory computer-readable storage medium to perform processing to parse the query in a given DML format into database constructs recognized by the database 400 and the optimizer 404.
The optimizer 404 is configured to execute on the at least one hardware processor 401 from the non-transitory computer-readable storage medium and to perform processing to use the predicted parsing execution time along with the database constructions to produce a query execution plan for the query.
In an embodiment, the database 400 is a data warehouse that includes the AMPs 104.
The above description is illustrative, and not restrictive. Many other embodiments will be apparent to those of skill in the art upon reviewing the above description. The scope of embodiments should therefore be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled.
Number | Name | Date | Kind |
---|---|---|---|
5511213 | Correa | Apr 1996 | A |
5761493 | Blakeley | Jun 1998 | A |
6061676 | Srivastava | May 2000 | A |
6182029 | Friedman | Jan 2001 | B1 |
6223205 | Harchol-Balter | Apr 2001 | B1 |
6321218 | Guay | Nov 2001 | B1 |
6353826 | Seputis | Mar 2002 | B1 |
6766320 | Homere | Jul 2004 | B1 |
8621482 | Ramesh | Dec 2013 | B1 |
8745065 | Wang | Jun 2014 | B2 |
9218390 | Feng et al. | Dec 2015 | B2 |
9355139 | Lewak | May 2016 | B2 |
9378243 | Korlapati | Jun 2016 | B1 |
9477707 | Chi | Oct 2016 | B2 |
9727942 | Nagai | Aug 2017 | B2 |
11055331 | Neumann | Jul 2021 | B1 |
11531657 | Sankaran | Dec 2022 | B1 |
11544236 | Brown | Jan 2023 | B2 |
20030009321 | Attwater | Jan 2003 | A1 |
20040249795 | Brockway | Dec 2004 | A1 |
20040249824 | Brockway | Dec 2004 | A1 |
20050055672 | Ramacher | Mar 2005 | A1 |
20050055673 | Dias | Mar 2005 | A1 |
20080195577 | Fan | Aug 2008 | A1 |
20080270346 | Mehta | Oct 2008 | A1 |
20090006343 | Platt | Jan 2009 | A1 |
20090037404 | Lee | Feb 2009 | A1 |
20090100004 | Andrei | Apr 2009 | A1 |
20090106214 | Jain | Apr 2009 | A1 |
20090299989 | Zhang | Dec 2009 | A1 |
20100082599 | Graefe | Apr 2010 | A1 |
20100235349 | Kuno | Sep 2010 | A1 |
20120089596 | Siddiqui | Apr 2012 | A1 |
20120130988 | Nica | May 2012 | A1 |
20120296936 | Nagatoshi | Nov 2012 | A1 |
20130151504 | Konig | Jun 2013 | A1 |
20140214793 | Tatemura | Jul 2014 | A1 |
20140214880 | Chi | Jul 2014 | A1 |
20140280035 | Fraser | Sep 2014 | A1 |
20150088919 | Hunter | Mar 2015 | A1 |
20160179890 | Chiang | Jun 2016 | A1 |
20160203404 | Cherkasova | Jul 2016 | A1 |
20170123877 | Gongloor | May 2017 | A1 |
20170323001 | Schwing | Nov 2017 | A1 |
20180278647 | Gabaev | Sep 2018 | A1 |
20180314735 | Liu | Nov 2018 | A1 |
20180336244 | Barsness | Nov 2018 | A1 |
20190258631 | Pal | Aug 2019 | A1 |
20200042647 | Pandey | Feb 2020 | A1 |
20230205596 | Sankaran | Jun 2023 | A1 |
Entry |
---|
Lee et al., “Regression-Based Self-Tuning Modeling of Smooth User-Defined Function Costs for an Object-Relational Database Management System Query Optimizer” 2004, University of Vermont. |
Ramesh et al., “Optimizer Time Estimation for SQL Queries”, ACM (Year: 2018). |
Xu et al., “Learning to Optimize Federated Queries”, University of Illinois (Year: 2019). |
Ganapathi et al., “Predicting Multiple Metrics for Queries: Better Decisions Enabled by Machine Learning”, IEEE (Year: 2009). |
Number | Date | Country | |
---|---|---|---|
20200183936 A1 | Jun 2020 | US |