The present invention relates generally to database management systems, and particularly to configuring database data to enable processing time-series analyses on the data.
Database management systems are used be used for storing and managing large amounts of data. A database engine can sort, change and present the information stored in the database. Two popular configurations for storing data in a database are row-based and column-based. Row-based databases have an ability to write data very quickly, and are therefore typically used for processing real-time transactions. Column-based database tables have an ability to aggregate large volumes of data for a subset of columns, and are therefore typically used for processing highly analytical queries.
The description above is presented as a general overview of related art in this field and should not be construed as an admission that any of the information it contains constitutes prior art against the present patent application.
There is provided, in accordance with an embodiment of the present invention, a method including capturing, by a processor, a series of point-in-time images of a database including one or more tables, each of the tables including one or more fields, receiving, from a user, a query with respect to a variation of a given field over a specified period of time, analyzing the point-in-time images in order to extract the variation, and presenting the extracted variation to the user.
In some embodiments, capturing the point-in-time images includes capturing the point-in-time images at predefined intervals.
In a first embodiment, a given table includes a customer relationship management data file.
In a second embodiment, a given table includes an enterprise resource planning file.
In a third embodiment, a given table includes an accounting data file.
In a fourth embodiment, a given table includes a customer service system data file.
In a fifth embodiment, a given table includes a messaging system data file.
In one embodiment, a given table includes a set of records, and wherein capturing a given point-in-time image of the database includes capturing the records in the given table.
In another embodiment, capturing the records includes capturing all the records in the given table.
In an additional, embodiment capturing the records includes capturing a subset the records in the given table.
In a further embodiment, analyzing the series of point-in-time images includes generating a database table including the series of point-in-time images, and querying the generated database table.
In a supplemental embodiment, generating a database table includes generating a column-based database table.
In one embodiment, the method also includes generating and maintaining a unified schema of the database that stores a schema change in the series of point-in-time images used to generate the database table.
In another embodiment, the series of point-in-time images includes a first given image including a first set of fields captured at a first time and a second given image including a second set of fields captured at a second time subsequent to the first time, and wherein the schema change includes a given field in the second set that is not in the first set.
In some embodiments, the point-in-time images captured during the specified period of time includes the first and the second given images, and wherein presenting the extracted variation includes presenting the first given image, and presenting, in the first image a specified value for the given field.
In an additional embodiment, the series of point-in-time images includes a first given image including a first set of fields captured at a first time and a second given image including a second set of fields captured at a second time subsequent to the first time, and wherein the schema change includes a given field in the first set that is not in the second set.
In some embodiments, the point-in-time images captured during the specified period of time includes the first and the second given images, and wherein presenting the extracted variation includes presenting the second given image, and presenting, in the second image a specified value for the given field.
In a further embodiment, the series of point-in-time images includes a first given image captured at a first time and a second given image including captured at a second time subsequent to the first time, wherein the first given image includes a field having a first data type, wherein the second given image includes a field having a second data type, and wherein the schema change includes a difference between the first and the second data types.
In some embodiments, the point-in-time images captured during the specified period of time includes the first and the second given images, and wherein presenting the extracted variation includes presenting the field in first given image and the second given image using a specified data type.
In a supplemental embodiment, the series of point-in-time images includes a set of fields, and wherein the database table includes a subset of the set of fields.
There is also provided, in accordance with an embodiment of the present invention, an apparatus, including a storage device, and at least one processor configured to capture and store to the storage device a series of point-in-time images of a database including one or more tables, each of the tables including one or more fields, to receive, from a user, a query with respect to a variation of a given field over a specified period of time, to analyze the point-in-time images in order to extract the variation, and to present the extracted variation to the user.
There is additionally provided, in accordance with an embodiment of the present invention, a computer software product for protecting a computing system, the product including a non-transitory computer-readable medium, in which program instructions are stored, which instructions, when read by a computer, cause the computer to capture a series of point-in-time images of a database including one or more tables, each of the tables including one or more fields, to receive, from a user, a query with respect to a variation of a given field over a specified period of time, to analyze the point-in-time images in order to extract the variation, and to present the extracted variation to the user.
The disclosure is herein described, by way of example only, with reference to the accompanying drawings, wherein:
Databases store data that can be updated on a continuing basis. Therefore, any queries on data stored in the database will typically be performed on current data stored in the database.
Embodiments of the present invention provide methods and systems for creating and managing database tables that can be used to process queries comprising time-based analytics of data stored in the database. As described hereinbelow, a series of point-in-time images of a database comprising one or more tables are captured, each of the tables comprising one or more fields. The term “point-in-time image” is used in the context of the present description and in the claims to refer to an image, i.e., a copy, of the data stored in one or more tables of a database at a specified point in time. Upon receiving, from a user, a query with respect to a variation of one of the tables over a specified period of time, the point-in-time images can be analyzed in order to extract the variation, and the extracted variation can be presented to the user.
In the configuration shown in
Data server 26 comprises a server processor 34, a server memory 36 and a server storage device 38. In some embodiments, memory 36 can store a data management application 40 that processor 34 can execute to manage a database 42 comprising data tables 24 stored on storage device 38. In the configuration shown in
In a first example, data management application 40 may comprise a database management system such as a structured query language (SQL) server (e.g., MICROSOFT SQL SERVER™, produced by Microsoft Corporation, One Microsoft Way Redmond, Wash. 98052-6399 USA), and data records 44 may comprise database tables.
In a second example, data management application 40 may comprise a customer relationship management (CRM) system such as SALESFORCE™ (produced by salesforce.com, inc., Salesforce Tower 3rd Floor, 415 Mission Street, San Francisco, Calif. 94105 USA) and data records 44 may comprise CRM data files such as standard or custom SALESFORCE™ objects.
In a third example, data management application 40 may comprise a customer service system such as ZENDESK™ (produced by Zendesk Inc., 1019 Market Street, San Francisco, Calif. 94103 USA), and data records 44 may store customer service system ticket data files.
In a fourth example, data management application 40 may comprise an enterprise resource planning (ERP) system such as NETSUITE™ (produced by Oracle Corporation, 500 Oracle Parkway, Redwood City, Calif. 94065 USA), and data records 44 may store ERP data files.
In a fifth example, data management application 40 may comprise an accounting system such as SAGE BUSINESS CLOUD ACCOUNTING™ (produced by The Sage Group plc, North Park, Newcastle upon Tyne NE13 9AA, United Kingdom), and data records 44 may store accounting data files.
In a sixth example, data management application 40 may comprise a messaging application such as SLACK™ (produces by Slack Technologies, Inc., 500 Howard Street, San Francisco, Calif. 94105 USA), and data records 44 may store messaging system data files.
In a seventh example, data management application 40 may comprise a project management application such as JIRA™ (produced by Atlassian Corporation Plc, 341 George Street, Level 6, Sydney, NSW 2000, Australia), and data records 44 may store project management data files.
In addition to these examples, any other type of application 40 that is configured to manage information stored in data records 44 is considered to be within the spirit and scope of the present invention.
In some embodiments, storage device 38 can store a data dictionary 48 that defines the layout and configuration of data fields 46 in data records 44.
Data analysis server 20 comprises an analysis processor 50, an analysis memory 52 and an analysis storage device 54. In some embodiments, processor 50 can execute, from memory 52, a partitioned database manager 56 that can perform embodiments described herein such as maintaining partitioned database 22, and processing queries for data stored in the partitioned database.
In the configuration shown in
In the configuration shown in
In some embodiments, the tasks performed by partitioned database manager 56 may be split among multiple physical and/or virtual computing devices. In other embodiments, the tasks performed by data management application 40 and/or partitioned database manager 56 may be performed in a data cloud.
Examples of memories 36, 52 and storage devices 38, 54 include dynamic random-access memories and non-volatile random-access memories. In some embodiments, the memories and/or the storage devices may comprise non-volatile storage devices such as hard disk drives and solid-state disk drives.
Processors 34 and 50 comprise general-purpose central processing units (CPU) or special-purpose embedded processors, which are programmed in software or firmware to carry out the functions described herein. This software may be downloaded to servers 20 and 26 in electronic form, over a network, for example. Additionally or alternatively, the software may be stored on tangible, non-transitory computer-readable media, such as optical, magnetic, or electronic memory media. Further additionally or alternatively, at least some of the functions of processors 34 and 50 may be carried out by hard-wired or programmable digital logic circuits.
As shown in
In the configuration shown in
In some embodiments, description file 72 comprises a set of field descriptions 82 that describe data fields 46 in data records 44 downloaded from the given data table. In some embodiments, raw data file 70 is populated the data fields in the downloaded table images. Field descriptions 82 have a one-to-one correspondence with field titles 78, and each of the field descriptions can store information such as:
In some embodiments, each raw data file 70 stores data from all the fields in its corresponding data table 24.
In the configuration shown in
In one embodiment, the table images downloaded on a given date may comprise all the data stored in the corresponding data tables 24. In another embodiment the table images downloaded on a given date may comprise deltas (i.e., additions, deletions and changes) from the most recent previous archive table images 60.
In an additional embodiment, partitioned database manager 56 can download a given table image 58 upon detecting a change (e.g., an addition, a deletion or an update) to a given date record 44 in a given data table 24. In this embodiment, the given table image may simply comprise the detected change (i.e., not the entire table 24).
In the configuration shown in
In embodiments of the present invention, partitioned database manager 56 creates a corresponding daily table 112 for a subset of archived table image 60. Therefore, for a given data table 24 having a plurality of corresponding archived table images 60, partitioned database manager 56 can create separate respective daily tables 112 for each of the corresponding archived table images 60. Deciding which daily tables 112 to create from archived image 60 is described in the description referencing
As described supra, each archived table image 60 comprises a copy of a given downloaded table image 58 that was captured at a specific point in time. In embodiments described herein, each daily image 112 comprises data from a corresponding archived table image 60 that was captured (i.e., from a given data table 24) at a specific point in time.
In some embodiments, partitioned database manager 56 can define each partitioned table 23 as a logical database table comprising set of physical daily tables 112. An example of a given partitioned table 23 implemented as a logical database table is described in the description referencing
To create daily table 112, partitioned database manager 56 can use information stored in a configuration file 118 and a unified schema file 120. Configuration file 118 is described in the description referencing
In some embodiments, processor 50 can create database directory structure 110 on storage device 38 as follows:
While the configuration of directory structure 110 in
Also, while the configuration of directory
In some embodiments, partitioned database manager 56 can store, to a given configuration record 140, a given table ID referencing a given partitioned table 23, and a null/empty value to field ID 146. The null/empty value indicates that partitioned database manager 56 will include all fields 80 in the corresponding raw data file 70 in the given partitioned table.
In embodiments of the present invention, the partitioned database fields in given partitioned table 23 typically comprise a subset of the raw data fields in the corresponding archived table image 60. This is because user 28 may not need to query information stored in all fields 80.
Partitioned database manager 56 can use the information stored in configuration file 118 to perform the following:
As described supra, partitioned database manager 56 can use configuration file 62 select which fields 80 to include in partitioned database 22. This is because partitioned database manager 56 downloads all fields 46 in tables 24 to images 58, and all the data fields might not be needed for analysis. However, there may by instances when there is a change to the configuration (i.e., layout) of a given data table 24. Example of these changes for the given table include:
In the configuration shown in
As described in the description referencing
As described in the description referencing
In
The example shown in
Additionally, while the example in
In step 180, partitioned database manager 56 creates, on storage device 54, a new day directory 108 for the given day. If the given day is the first day of a month, partitioned database manager 56 will create a new month directory 106 prior to creating new directory 108. If the given day is the first day of a year, partitioned database manager 56 will create a new year directory 104 prior to creating new directory 106.
In step 182, partitioned database manager 56 selects a given data table 24, and in step 184, the partitioned database manager conveys, to data server 26, a request to retrieve a plurality of records 44 from the given data table. In one embodiment, the request may comprise a request to retrieve all records 44 in the given data table. In another embodiment, the request may comprise a request to only retrieve changes to the records in the given data table.
In step 186, partitioned database manager 56 receives (i.e., captures) the requested records, and stores them to storage device 54.
In step 188, partitioned database manager 56 creates, using the downloaded records (i.e., downloaded from the selected table 24), a new table image 58. Upon creating new table image 58, partitioned database manager 56 copies the created table image 58 to a new archived table image 60 in the new archive directory.
In step 190 partitioned database manager 56 checks table IDs 144 in configuration records 140 to see if a given partitioned table 23 is to be generated from the data table 26 selected in step 182. If a given partitioned table 23 is to be generated from the selected data table, then in step 192, partitioned database manager 56 creates, in the table directory 124 corresponding to the given data table, a new day directory 130 for the given day. If the given day is the first day of a month, partitioned database manager 56 will create a new month directory 128 prior to creating new directory 130. If the given day is the first day of a year, partitioned database manager 56 will create a new year directory 126 prior to creating new directory 128.
In step 194, partitioned database manager 56 identifies, in configuration file 118, which raw data fields 80 are to be included a new partitioned table 23 corresponding to the given data table. As describe supra, configuration 118 file may store field IDs 146 that are to be excluded from the new partitioned table. Partitioned database manager 56 can use this information to create the new partitioned table.
In step 196, partitioned database manager 56 generates, using the data stored in the identified raw data fields 80, a new partitioned database table 23, and in step 198 the partitioned database manager moves the created partitioned database table to the new day directory 130 (i.e., the day directory created in step 192).
Upon performing step 198, partitioned database manager 56 can analyze the identified fields to see if there is are any changes to the identified raw data fields 80 that require a change to unified schema file 120. As described supra, examples of changes can include a new raw data field 80, a deleted raw data field 80 or a change of the data type for a given raw data field.
In step 200, if partitioned database manager 56 detects a change that requires a change to unified schema file 120, then in step 202, the partitioned database manager updates the unified schema file 120 accordingly.
Finally, in step 204, if there are additional remote data tables 24 that were not yet selected in step 184, then the method continues with step 184. In other words, step 184, only selects previously unselected remote data tables 24.
Returning to step 204, if there are no unselected remote data tables 24, then the method ends.
Returning to step 200, if partitioned database manager 56 does not detect any change that requires a change to unified schema file 120, then the method continues with step 204. Returning to step 190, if a given partitioned table 23 is not to be generated from the selected data table, then the method continues with step 204.
In step 210, partitioned database manager 56 receives, from user 28 (i.e., via client computer 30), a query with respect to a variation of a given field 174 in table 170 over a specified period of time. As described supra, table 170 comprises multiple partitioned tables 23.
For example, the query may comprise a request to identify how many names 174D were added and/or deleted and/or updated on Nov. 12, 2020.
In step 212, partitioned database manager 56 identifies records 172 for the specified period of time, and in step 214, the partitioned database manager analyzes the identified records in order to extract the variation.
Continuing the example described supra, partitioned database manager 56 can perform step 212 by:
Finally, in step 216, partitioned database manager 56 presents the extracted variation to user 28, and the method ends. To present the extracted variation to user 28, partitioned database manager 56 can convey the extracted variation to client computer 30, and upon receiving the extracted variation, the client computer can present the extracted variation on display 64.
In step 220, partitioned database manager 56 selects, from configuration file 118, a given table ID 144 corresponding to a given partitioned database table 23.
In step 222, partitioned database manager 56 identifies the archived table images 60 corresponding to the given table 23.
In step 224, partitioned database manager 56 selects a given identified archive table image 60, and in step 226 the partitioned database manager deletes the existing daily database table 112 that corresponds to the selected archive table image 60.
In step 228, partitioned database manager 56 uses the given identified archive image to recreate, using the information stored in configuration file 118, the daily table 112 corresponding to the given identified archive image.
In step 230, if partitioned database manager 56 identifies any of the identified table images (i.e., in step 222) that were not yet selected (i.e., in step 224), then the method continues with step 224.
When partitioned database manager 56 determines that all the identified table images have been selected, then in step 232, partitioned database manager 56 determines if there are any table ids 144 that have not yet been selected in step 220.
If there are any table ids 144 that have not yet been selected in step 220, then the method continues with step 220. If all the table ids 144 have already been selected, then the method ends.
It will be appreciated that the embodiments described above are cited by way of example, and that the present invention is not limited to what has been particularly shown and described hereinabove. Rather, the scope of the present invention includes both combinations and subcombinations of the various features described hereinabove, as well as variations and modifications thereof which would occur to persons skilled in the art upon reading the foregoing description and which are not disclosed in the prior art.
Number | Name | Date | Kind |
---|---|---|---|
6460055 | Midgley | Oct 2002 | B1 |
8364648 | Sim-Tang | Jan 2013 | B1 |
8732213 | Sowell et al. | May 2014 | B2 |
11080336 | Van Dusen | Aug 2021 | B2 |
11157463 | Barabas | Oct 2021 | B2 |
11269731 | Vig et al. | Mar 2022 | B1 |
20080121690 | Carani | May 2008 | A1 |
20080313005 | Nessland | Dec 2008 | A1 |
20120169842 | Chuang | Jul 2012 | A1 |
20120191682 | Banerjee et al. | Jul 2012 | A1 |
20130166568 | Binkert et al. | Jun 2013 | A1 |
20130218840 | Smith et al. | Aug 2013 | A1 |
20130275462 | Jung | Oct 2013 | A1 |
20130297610 | Devarakonda | Nov 2013 | A1 |
20140058801 | Deodhar | Feb 2014 | A1 |
20140173135 | Varney et al. | Jun 2014 | A1 |
20140351217 | Bostock | Nov 2014 | A1 |
20150156213 | Baker | Jun 2015 | A1 |
20160092484 | Finkler | Mar 2016 | A1 |
20170116552 | Deodhar | Apr 2017 | A1 |
20170329983 | Grant | Nov 2017 | A1 |
20170344593 | Mullick et al. | Nov 2017 | A1 |
20180285201 | Bangalore | Oct 2018 | A1 |
20200089798 | Ganichot | Mar 2020 | A1 |
20200110792 | Tsabba | Apr 2020 | A1 |
20200389495 | Crabtree | Dec 2020 | A1 |
20210019288 | Pang | Jan 2021 | A1 |
20210326793 | Frankel | Oct 2021 | A1 |
20220197904 | Gillis | Jun 2022 | A1 |
20220334725 | Mertes et al. | Oct 2022 | A1 |
Number | Date | Country |
---|---|---|
2131284 | Dec 2009 | EP |
Entry |
---|
International Application # PCT/IB2021/055251 Search Report dated Oct. 10, 2021. |
Oracle, “Oracle Autonomous Database,” pp. 1-16, year 2021, as downloaded from https://www.oracle.com/autonomous-database/. |
Google, “Trusting your data with Google Cloud Platform”, Whitepaper, pp. 1-17, Sep. 2019. |
Kunzle et al., U.S. Appl. No. 17/528,290, filed Nov. 17, 2021. |
International Application # PCT/IB2021/060550 Search Report dated Feb. 24, 2022. |
Kunzle et al., U.S. Appl. No. 63/115,076, filed Nov. 18, 2020. |
Oracle, “Netsuite Erp”, data sheet, pp. 1-2, Jun. 4, 2019. |
Sage Group PLC, “Sage Business Cloud Accounting”, Product Brochure, pp. 1-6, Apr. 28, 2020. |
Salesforce, “change Data Capture Developer Guide”, Version 49.0, pp. 1-65, Sep. 1, 2020. |
Slack Technologies, “Data Management Transparency and Control”, pp. 1-5, Sep. 27, 2020. |
Microsoft Corporation, “SQL Server 2019 editions”, pp. 1-3, Oct. 29, 2019. |
Sureka, A., “28 Important Zendesk features for Better Customer Support”, pp. 1-12, Jan. 15, 2019 downloaded from https://www.clariontech.com/platform-blog/28-important-zendesk-features-for-better-customer-support. |
Nevogt, D., “JIRA Project Management: A How-To Guide for Beginners”, pp. 1-17, May 16, 2019 downloaded from https://blog.hubstaff.com/jira-project-management-guide-beginners/. |
U.S. Appl. No. 17/528,290 Office Action dated Nov. 10, 2022. |
Number | Date | Country | |
---|---|---|---|
20220156310 A1 | May 2022 | US |