What does parsing a query mean?

2019-03-13 16:48发布

问题:

Most relational databases handles a JDBC / SQL query in four steps:

  1. Parse the incoming SQL query
  2. Compile the SQL query
  3. Plan/optimize the data acquisition path
  4. Execute the optimized query / acquire and return data

I want to know what does "parse the incoming query" really mean? And what does "plan/optimize data acquisition path" mean?

回答1:

Parsing is one stage in the processing of a SQL statement. When an application issues a SQL statement, the application makes a parse call to Database. During the parse call, Database:

  1. Checks the statement for syntactic and semantic validity.
  2. Determines whether the process issuing the statement has privileges to run it.
  3. Allocates a private SQL area for the statement.


回答2:

parsing is one of the Process of compilation.

Phases of a Compiler:

Source: Phases of Compiler



回答3:

  1. Parsing means examining the characters input and recognizing it as a command or statement by looking through the characters for keywords and identifiers, ignoring comments, arranging quoted portions as string constants, and matching the overall structure to the language syntax making sense of it all.

  2. Plan/optimize means figure out the best way (of all the possible ways) to determine the result, usually with respect to execution time. It could also mean minimizing the number of locks needed. Maybe some parts of the query can be ignored (where ... and 1 == 1) or a table doesn't need to be accessed at all, etc.



回答4:

1) Parsing: syntactic analysis of the query according to the SQL grammar rules, etc. and attempting to "tokenize" the query into the elementary parts form.

2) Planning/optimization: at that stage the SQL engine tries to evaluate what the best way to execute your query would be. It tries to take advantage of existing indexes, clusters and table relationships; find ways around full table scans, utilize caching effectively by avoiding repeated data reads, and so forth.