Tracking intermediate changes in database data

US12026153B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-12026153-B2
Application numberUS-202318179762-A
CountryUS
Kind codeB2
Filing dateMar 7, 2023
Priority dateNov 6, 2018
Publication dateJul 2, 2024
Grant dateJul 2, 2024

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Systems, methods, and devices for tracking a series of changes to database data are disclosed. A method includes executing a transaction to modify data in a micro-partition of a table of a database by generating a new micro-partition that embodies the transaction. The method includes associating transaction data with the new micro-partition, wherein the transaction data comprises a timestamp when the transaction was fully executed, and further includes associating modification data with the new micro-partition that comprises an indication of one or more rows of the table that were modified by the transaction. The method includes joining the transaction data with the modification data to generate joined data and querying the joined data to determine a listing of intermediate modifications made to the table between a first timestamp and a second timestamp.

First claim

Opening claim text (preview).

What is claimed is: 1. A method comprising: storing data in a first micro-partition of a table; executing a transaction related to the stored data in the first micro-partition to generate transaction data; performing a plurality of modifications to the stored data in the first micro-partition to generate a second micro-partition and remove the first micro-partition from the table for executing the transaction; generating a delta table, the delta table storing final changes to the stored data in the second micro-partition from the first micro-partition; generating modification data, the modification data tracking the modifications performed to the stored data between the second micro-partition and the first micro-partition; and joining the modification data with the transaction data to generate joined data, the joined data indicating intermediate changes to the stored data between the second micro-partition and the first micro-partition. 2. The method of claim 1 , further comprising: determining tuple changes between each of a series of sequential micro-partition pairs between the first and second micro-partitions. 3. The method of claim 1 , wherein multiple modifications to a row of a plurality of rows in the first micro-partition are performed and the joined data indicates at least one intermediate change to the row between initial and final values. 4. The method of claim 1 , wherein the transaction data includes one or more of: an identity of an account that initiated the transaction, a first timestamp when the transaction was requested, a second timestamp when execution of the transaction began, a listing of all rows that were modified by the transaction, and details of the modifications. 5. The method of claim 1 , wherein the modification data is stored in the second micro-partition as metadata, wherein the modification data includes a lineage of modifications made to the table. 6. The method of claim 1 , wherein the transaction data and the modification data are stored in the second micro-partition as metadata in immutable storage. 7. The method of claim 1 , further comprising: wherein the delta table includes information indicating which rows have been modified, final values of rows that have been modified between the first and second micro-partitions, and an action type of the modification for each row modified. 8. A system comprising: one or more processors of a machine; and a memory storing instructions that, when executed by the one or more processors, cause the machine to perform operations comprising: storing data in a first micro-partition of a table; executing a transaction related to the stored data in the first micro-partition to generate transaction data; performing a plurality of modifications to the stored data in the first micro-partition to generate a second micro-partition and remove the first micro-partition from the table for executing the transaction; generating a delta table, the delta table storing final changes to the stored data in the second micro-partition from the first micro-partition; generating modification data, the modification data tracking the modifications performed to the stored data between the second micro-partition and the first micro-partition; and joining the modification data with the transaction data to generate joined data, the joined data indicating intermediate changes to the stored data between the second micro-partition and the first micro-partition. 9. The system of claim 8 , the operations further comprising: determining tuple changes between each of a series of sequential micro-partition pairs between the first and second micro-partitions. 10. The system of claim 8 , wherein multiple modifications to a row of a plurality of rows in the first micro-partition are performed and the joined data indicates at least one intermediate change to the row between initial and final values. 11. The system of claim 8 , wherein the transaction data includes one or more of: an identity of an account that initiated the transaction, a first timestamp when the transaction was requested, a second timestamp when execution of the transaction began, a listing of all rows that were modified by the transaction, and details of the modifications. 12. The system of claim 8 , wherein the modification data is stored in the second micro-partition as metadata, wherein the modification data includes a lineage of modifications made to the table. 13. The system of claim 8 , wherein the transaction data and the modification data are stored in the second micro-partition as metadata in immutable storage. 14. The system of claim 8 , wherein the delta table includes information indicating which rows have been modified, final values of rows that have been modified between the first and second micro-partitions, and an action type of the modification for each row modified. 15. A non-transitory computer readable storage media storing instructions that, when executed by one or more processors, cause the one or more processors to: storing data in a first micro-partition of a table; executing a transaction related to the stored data in the first micro-partition to generate transaction data; performing a plurality of modifications to the stored data in the first micro-partition to generate a second micro-partition and remove the first micro-partition from the table for executing the transaction; generating a delta table, the delta table storing final changes to the stored data in the second micro-partition from the first micro-partition; generating modification data, the modification data tracking the modifications performed to the stored data between the second micro-partition and the first micro-partition; and joining the modification data with the transaction data to generate joined data, the joined data indicating intermediate changes to the stored data between the second micro-partition and the first micro-partition. 16. The non-transitory computer readable storage media of claim 15 , further comprising: determining tuple changes between each of a series of sequential micro-partition pairs between the first and second micro-partitions. 17. The non-transitory computer readable storage media of claim 15 , wherein multiple modifications to a row of a plurality of rows in the first micro-partition are performed and the joined data indicates at least one intermediate change to the row between initial and final values. 18. The non-transitory computer readable storage media of claim 15 , wherein the transaction data includes one or more of: an identity of an account that initiated the transaction, a first timestamp when the transaction was requested, a second timestamp when execution of the transaction began, a listing of all rows that were modified by the transaction, and details of the modifications. 19. The non-transitory computer readable storage media of claim 15 , wherein the modification data is stored in the second micro-partition as metadata, wherein the modification data includes a lineage of modifications made to the table. 20. The non-transitory computer readable storage media of claim 15 , wherein the transaction data and the modification data are stored in the second micro-partition as metadata in immutable storage. 21. The non-transitory computer readable storage media of claim 15 , wherein the delta table includes information indicating which rows have been modified, final values of rows that have been modified between the first and second micro-part

Assignees

Inventors

Classifications

  • Unary operations; Data partitioning operations · CPC title

  • Join operations · CPC title

  • Tablespace storage structures; Management thereof · CPC title

  • Updates performed during online database operations; commit processing · CPC title

  • G06F16/219Primary

    Managing data history or versioning (querying versioned data G06F16/2474; querying temporal data G06F16/2477) · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US12026153B2 cover?
Systems, methods, and devices for tracking a series of changes to database data are disclosed. A method includes executing a transaction to modify data in a micro-partition of a table of a database by generating a new micro-partition that embodies the transaction. The method includes associating transaction data with the new micro-partition, wherein the transaction data comprises a timestamp wh…
Who is the assignee on this patent?
Snowflake Inc
What technology area does this patent fall under?
Primary CPC classification G06F16/2379. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jul 02 2024 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).