Query optimizer with schema conversion
First Claim
Patent Images
1. A method comprising:
- determining, for a database query that does not represent a snowflake schema, a graph comprising (a) vertices each representing a table joined in the query, (b) a directed edge between each pair of vertices of which a first vertex represents a first table and a second vertex represents a second table that is joined in the query with the first table, each of the edges representing one of an outer join and an inner join;
determining, for the graph, a directed spanning tree that (a) represents an ordering of joins in the query and includes all outer join edges in the graph, (b) does not include a first subtree having an outer join edge directed from a first vertex to a second vertex, and an inner join edge directed from the second vertex to a third vertex, (c) does not include a second subtree having an outer join edge directed from a fourth vertex to a fifth vertex, and another outer join edge directed from the fourth vertex to a sixth vertex; and
the spanning tree being a sufficient basis for a physical plan to obtain data records that satisfy the query.
9 Assignments
0 Petitions
Accused Products
Abstract
Methods, program products and systems for determining, for a database query that does not represent a snowflake schema, a graph comprising vertices each representing a table joined in the query, a directed edge between each pair of vertices of which a first vertex represents a first table and a second vertex represents a second table that is joined in the query with the first table, each of the edges representing one of an outer join and an inner join. Further determining, for the graph, a directed spanning tree that represents an ordering of joins in the query and includes all outer join edges in the graph.
-
Citations
28 Claims
-
1. A method comprising:
-
determining, for a database query that does not represent a snowflake schema, a graph comprising (a) vertices each representing a table joined in the query, (b) a directed edge between each pair of vertices of which a first vertex represents a first table and a second vertex represents a second table that is joined in the query with the first table, each of the edges representing one of an outer join and an inner join; determining, for the graph, a directed spanning tree that (a) represents an ordering of joins in the query and includes all outer join edges in the graph, (b) does not include a first subtree having an outer join edge directed from a first vertex to a second vertex, and an inner join edge directed from the second vertex to a third vertex, (c) does not include a second subtree having an outer join edge directed from a fourth vertex to a fifth vertex, and another outer join edge directed from the fourth vertex to a sixth vertex; and the spanning tree being a sufficient basis for a physical plan to obtain data records that satisfy the query. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 10)
-
-
11. A computer program product, encoded on a computer-readable medium, operable to cause data processing apparatus to perform operations comprising:
-
determining, for a database query that does not represent a snowflake schema, a graph comprising (a) vertices each representing a table joined in the query, (b) a directed edge between each pair of vertices of which a first vertex represents a first table and a second vertex represents a second table that is joined in the query with the first table, each of the edges representing one of an outer join and an inner join; determining, for the graph, a directed spanning tree that (a) represents an ordering of joins in the query and includes all outer join edges in the graph, (b) does not include a first subtree having an outer join edge directed from a first vertex to a second vertex, and an inner join edge directed from the second vertex to a third vertex, (c) does not include a second subtree having an outer join edge directed from a fourth vertex to a fifth vertex, and another outer join edge directed from the fourth vertex to a sixth vertex; and the spanning tree being a sufficient basis for a physical plan to obtain data records that satisfy the query. - View Dependent Claims (12, 13, 14, 15, 16, 17, 18, 19)
-
-
20. A system comprising:
-
a machine-readable storage device including a program product; and one or more processors configured to interact with the storage device, execute the program product and perform operations comprising; determining, for a database query that does not represent a snowflake schema, a graph comprising (a) vertices each representing a table joined in the query, (b) a directed edge between each pair of vertices of which a first vertex represents a first table and a second vertex represents a second table that is joined in the query with the first table, each of the edges representing one of an outer join and an inner join; determining, for the graph, a directed spanning tree that (a) represents an ordering of joins in the query and includes all outer join edges in the graph, (b) does not include a first subtree having an outer join edge directed from a first vertex to a second vertex, and an inner join edge directed from the second vertex to a third vertex, (c) does not include a second subtree having an outer join edge directed from a fourth vertex to a fifth vertex, and another outer join edge directed from the fourth vertex to a sixth vertex; and the spanning tree being a sufficient basis for a physical plan to obtain data records that satisfy the query. - View Dependent Claims (21, 22, 23, 24, 25, 26, 27, 28)
-
Specification