Method of servicing query statements from a client machine using a database management system (DBMS) employing a relational datastore and a multi-dimensional database (MDDB)
First Claim
1. A database management system comprising:
- a relational data store storing fact data;
a multi-dimensional data store configured to store aggregated fact data in a multi-dimensional data structure and to communicate bi-directionally with the relational data store;
a communication interface operably connected between the relational data store and the multi-dimensional data store for communication of fact data from the relational data store to the multi-dimensional data store and for the communication of aggregated fact data from the multi-dimensional data store to the relational data store; and
a computer system comprising computer hardware, the computer system programmed to implement;
a query servicing mechanism configured to service one or more natural language queries from a user, the query servicing mechanism comprising;
a query processing mechanism configured to process a given natural language query, the query processing mechanism configured to;
make a determination of whether servicing the given natural language query needs data stored in the relational data store or the multi-dimensional data store; and
upon a determination that servicing the given natural language query needs data stored in the multi-dimensional data store,
automatically calculate the aggregated fact data and forwarding the calculated aggregated fact data to the query processing mechanism for use in servicing the given natural language query, in a manner transparent to the user.
8 Assignments
0 Petitions
Accused Products
Abstract
A method of serving query statements from one or more client machines using a database management system (DBMS) employing a relational data store and a multi-dimensional database (MDDB). A query interface is adapted to receive query statements from the client machines, and generate one or more query requests. A query handling mechanism (i) receives each request from the query interface, (ii) extracts a set of dimensions associated with the request, (iii) uses the dimensions to retrieve aggregated fact data from the MDDB, and (iv) forwards retrieved aggregated fact data to the query processing mechanism for subsequent processing. When the query processing mechanism determines that servicing of one or more query requests require data stored in the relational tables, then the query handling mechanism automatically routes the requests to the relational data tables, so that data can be accessed from the relational tables and forwarded to the query processing mechanism for use in servicing the requests, in a manner transparent to the client machine.
332 Citations
13 Claims
-
1. A database management system comprising:
-
a relational data store storing fact data; a multi-dimensional data store configured to store aggregated fact data in a multi-dimensional data structure and to communicate bi-directionally with the relational data store; a communication interface operably connected between the relational data store and the multi-dimensional data store for communication of fact data from the relational data store to the multi-dimensional data store and for the communication of aggregated fact data from the multi-dimensional data store to the relational data store; and a computer system comprising computer hardware, the computer system programmed to implement; a query servicing mechanism configured to service one or more natural language queries from a user, the query servicing mechanism comprising; a query processing mechanism configured to process a given natural language query, the query processing mechanism configured to; make a determination of whether servicing the given natural language query needs data stored in the relational data store or the multi-dimensional data store; and upon a determination that servicing the given natural language query needs data stored in the multi-dimensional data store,
automatically calculate the aggregated fact data and forwarding the calculated aggregated fact data to the query processing mechanism for use in servicing the given natural language query, in a manner transparent to the user. - View Dependent Claims (2, 3, 4, 5)
-
-
6. A method comprising:
by a computer system comprising computer hardware; receiving one or more natural language queries from a user; determining whether servicing a given natural language query of the one or more natural language queries needs data stored in a relational data store or in a multi-dimensional data store, wherein the relational data store is configured to communicate fact data to the multi-dimensional data store and the multi-dimensional data store is configured to communicate aggregated fact data to the relational data store; and in response to determining that servicing the given natural language query needs data stored in the multi-dimensional data store, automatically calculating aggregated fact data and forwarding the calculated aggregated fact data to the user. - View Dependent Claims (7, 8, 9)
-
10. A non-transitory computer-readable medium having instructions stored thereon that, if executed by a computing device, cause the computing device to perform operations comprising:
-
receiving one or more natural language queries from a user; determining whether servicing a given natural language query needs data stored in a relational data store or in a multi-dimensional data store formed via a segmented aggregation process involving aggregation along multiple dimensions in a determined sequence, wherein the multi-dimensional data store is configured to communicate bi-directionally with the relational data store; and in response to determining that servicing the given natural language query needs data stored in the multi-dimensional data store, automatically calculating aggregated fact data and forwarding the calculated aggregated fact data to the user. - View Dependent Claims (11, 12, 13)
-
Specification