Hash index
US-2018011893-A1 · Jan 11, 2018 · US
US11860830B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-11860830-B2 |
| Application number | US-201916287569-A |
| Country | US |
| Kind code | B2 |
| Filing date | Feb 27, 2019 |
| Priority date | Sep 21, 2013 |
| Publication date | Jan 2, 2024 |
| Grant date | Jan 2, 2024 |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
Official abstract text for this publication.
Columns of a table are stored in either row-major format or column-major format in an in-memory DBMS. For a given table, one set of columns is stored in column-major format; another set of columns for a table are stored in row-major format. This way of storing columns of a table is referred to herein as dual-major format. In addition, a row in a dual-major table is updated “in-place”, that is, updates are made directly to column-major columns without creating an interim row-major form of the column-major columns of the row. Users may submit database definition language (“DDL”) commands that declare the row-major columns and column-major columns of a table.
Opening claim text (preview).
The invention claimed is: 1. A method, said method comprising steps of: a database server receiving a data definition language (DDL) statement that declares a table in a database and table columns of said table; wherein said database includes a database dictionary that defines database objects of said database; wherein said DDL statement declares: one or more column-major columns of said table columns, and row-major columns of said table columns; in response to receiving said DDL statement, creating said table by at least generating metadata in said database dictionary that defines: said table, said one or more column-major columns of said table, and said row-major columns of said table; storing rows in said table, wherein storing rows in said table comprises storing said one or more column-major columns of said rows in column-major format and storing said row-major columns of said rows in row-major format; receiving a data manipulation language (DML) statement requesting to update a column value of a column-major column of said one or more column-major columns; and in response to receiving said DML statement, updating in said database said column-major column in-place to a new value. 2. The method of claim 1 , wherein storing comprises: storing said row-major columns in a row partition comprising row pages; storing said one or more column-major columns in one or more column partitions, each column partition of said one or more column partitions comprising column pages; wherein the method further comprises: executing a database transaction, wherein executing said database transaction comprises said updating; committing said database transaction; and wherein said updating comprises storing said new value in a column page of said one or more column partitions before committing said database transaction. 3. The method of claim 1 , wherein storing comprises: storing said row-major columns in a row partition comprising row pages, each row page of said row pages comprising a plurality of row slots; storing said one or more column-major columns in one or more column partitions, each column partition of said one or more column partitions comprising column pages, each column page of said column pages comprising column slots; wherein based on a functional mapping, a row slot in said row partition has a one-to-one association with a column slot in each column partition of said one or more column partitions. 4. The method of claim 3 , the steps further comprising: determining a location of a row in said row partition; and based on said functional mapping and said location of said row in said row partition, for each column partition of said one or more column partitions, determining a location of a column value of said row in said each column partition. 5. The method of claim 3 , the method further including: determining a location of a row in a column partition of said one or more column partitions; and based on said functional mapping and said location of said row in said column partition, determining a location of said row in said row partition. 6. The method of claim 3 , wherein at least one column partition of said one or more column partitions is compressed using run-length encoding. 7. The method of claim 6 , where the steps further comprise: based on a location of a row in said row partition, traversing an index that indexes said at least one column partition to determine a location of an encoded run in said at least one column partition corresponding to a column of said row. 8. The method of claim 7 , the steps further comprising: determining a location of a column value in said at least one column partition; and based on said index and said location of said column, determining a location of a row holding said column value. 9. The method of claim 3 , wherein for one or more column pages of said one or more column partitions, each column page of said one or more column pages is associated with a Bloom filter derived from column values in said each column page. 10. One or more non-transitory computer-readable media storing sequences of instructions, which, when executed by one or more processors, cause: a database server receiving a data definition language (DDL) statement that declares a table in a database and table columns of said table; wherein said database includes a database dictionary that defines database objects of said database; wherein said DDL statement declares: one or more column-major columns of said table columns, and row-major columns of said table columns; in response to receiving said DDL statement, creating said table by at least generating metadata in said database dictionary that defines: said table, said one or more column-major columns of said table, and said row-major columns of said table; storing rows in said table, wherein storing rows in said table comprises storing said one or more column-major columns of said rows in column-major format and storing said row-major columns of said rows in row-major format; receiving a DML statement requesting to update a column value of a column-major column of said one or more column-major columns; and in response to receiving said DML statement, updating in said database said column-major column in-place to a new value. 11. The one or more non-transitory computer-readable media of claim 10 , wherein storing comprises: storing said row-major columns in a row partition comprising row pages; storing said one or more column-major columns in one or more column partitions, each column partition of said one or more column partitions comprising column pages; wherein the sequences of instructions include instructions, that when executed by said one or more processors, cause: executing a database transaction, wherein executing said database transaction comprises said updating; committing said database transaction; and wherein said updating comprises storing said new value in a column page of said one or more column partitions before committing said database transaction. 12. The one or more non-transitory computer-readable media of claim 10 , wherein storing comprises: storing said row-major columns in a row partition comprising row pages, each row page of said row pages comprising a plurality of row slots; storing said one or more column-major columns in one or more column partitions, each column partition of said one or more column partitions comprising column pages, each column page of said column pages comprising column slots; wherein based on a functional mapping, a row slot in said row partition has a one-to-one association with a column slot in each column partition of said one or more column partitions. 13. The one or more non-transitory computer-readable media of claim 12 , the sequences of instructions including instructions, that when executed by said one or more processors, cause: determining a location of a row in said row partition; and based on said functional mapping and said location of said row in said row partition, for each column partition of said one or more column partitions, determining a location of a column value of said row in said each column partition. 14. The one or more non-transitory computer-readable media of claim 12 , the sequences of instructions including instructions, that when executed by said one or more processors, cause: determining a location of a row in a column partition of said one or more column partitions; and based on said functional mapping and said location of said row in said column partition, determining a location of said row in said row
Schema design and management · CPC title
Design, administration or maintenance of databases · CPC title
Data partitioning, e.g. horizontal or vertical partitioning · CPC title
Related publications grouped by family.
Answers are generated from the same data shown on this page.