System, method, and computer-readable medium for iteratively dynamically assigning data objects to a plurality of processing modules of a database system

US2020201680A1 · US · A1

Patent metadata
FieldValue
Publication numberUS-2020201680-A1
Application numberUS-201816224851-A
CountryUS
Kind codeA1
Filing dateDec 19, 2018
Priority dateDec 19, 2018
Publication dateJun 25, 2020
Grant date

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.

A database system comprises a plurality of processing modules arranged to process data objects from a plurality of data object servers based upon a database query from a client computer system. A control task module is arranged to iteratively dynamically assign data objects from the plurality of data object servers to each of the plurality of processing modules based upon processing activity associated with the processing module during the database query from the client computer system. Alternatively, or in addition to, the control task module is arranged to iteratively dynamically assign data objects from the plurality of data object servers to each of the plurality of processing modules based upon a characteristic of the data objects to be dynamically assigned to the processing module during the database query from the client computer system.

First claim

Opening claim text (preview).

What is claimed is: 1 . A database system comprising: a plurality of processing modules arranged to process data objects from a plurality of data object servers based upon a database query from a client computer system; and a control task module arranged to iteratively dynamically assign data objects from the plurality of data object servers to each of the plurality of processing modules based upon processing activity associated with the processing module during the database query from the client computer system. 2 . A database system according to claim 1 , wherein the control task module comprises a portion of one of the plurality of processing modules. 3 . A database system according to claim 1 further comprising: a first communications network connected between the client computer system and each module; and a second communications network connected between the plurality of data object servers and each module. 4 . A database system according to claim 1 , wherein processing activity of each processing module during the database query comprises a number of output rows being generated by the processing module. 5 . A database system according to claim 1 , wherein processing activity of each processing module during the database query comprises random processing activity associated with the processing module. 6 . A database system comprising: a plurality of processing modules arranged to process data objects from a plurality of data object servers based upon a database query from a client computer system; and a control task module arranged to iteratively dynamically assign data objects from the plurality of data object servers to each of the plurality of processing modules based upon a characteristic of the data objects to be dynamically assigned to the processing module during the database query from the client computer system. 7 . A database system according to claim 6 , wherein the control task module comprises a portion of one of the plurality of processing modules. 8 . A database system according to claim 6 further comprising: a first communications network connected between the client computer system and each module; and a second communications network connected between the plurality of data object servers and each module. 9 . A database system according to claim 6 , wherein the characteristic of the data objects to be dynamically assigned to the processing module comprises size of one or more data objects to be assigned to the processing module. 10 . A database system according to claim 6 , wherein the characteristic of the data objects to be dynamically assigned to the processing module comprises a collection of small batches of data objects to be dynamically assigned to the processing module. 11 . A method for assigning data objects to a plurality of processing modules of a database system to improve performance of the database system, the method comprising: receiving a database query from a client computer system; and iteratively dynamically assigning data objects from a plurality of data object servers to each processing module based upon a select one of (i) processing activity of the processing module, and (ii) a characteristic of the data objects to be dynamically assigned to the processing module. 12 . A method according to claim 11 , wherein receiving a database query from a client computer system includes: receiving a database query involving execution of a join operator. 13 . A method according to claim 11 , wherein iteratively dynamically assigning data objects from a plurality of data object servers to each processing module based upon a select one of (i) processing activity of the processing module, and (ii) a characteristic of the data objects to be dynamically assigned to the processing module includes: iteratively dynamically assigning data objects from a plurality of data object servers to each processing module based upon both processing activity of the processing module and a characteristic of the data objects to be dynamically assigned to the processing module. 14 . A method according to claim 11 , wherein iteratively dynamically assigning data objects from a plurality of data object servers to each processing module based upon a select one of (i) processing activity of the processing module, and (ii) a characteristic of the data objects to be dynamically assigned to the processing module includes: iteratively dynamically assigning data objects from a plurality of data object servers to each processing module based upon a number of output rows being generated by the processing module. 15 . A method according to claim 11 , wherein iteratively dynamically assigning data objects from a plurality of data object servers to each processing module based upon a select one of (i) processing activity of the processing module, and (ii) a characteristic of the data objects to be dynamically assigned to the processing module includes: iteratively dynamically assigning data objects from a plurality of data object servers to each processing module based upon size of one or more data objects to be dynamically assigned to the processing module. 16 . A method according to claim 11 further comprising: dynamically reassigning data objects from a processing module that is unable to process its assigned data objects to remaining processing modules so that the remaining processing modules can process the reassigned data objects. 17 . A method according to claim 16 , wherein dynamically reassigning data objects from a processing module that is unable to process its assigned data objects to remaining processing modules so that the remaining processing modules can process the reassigned data objects includes: dynamically reassigning data objects to a processing module based upon processing speed of the processing module to which the data objects are reassigned. 18 . A method according to claim 16 , wherein dynamically reassigning data objects from a processing module that is unable to process its assigned data objects to remaining processing modules so that the remaining processing modules can process the reassigned data objects includes: dynamically reassigning data objects to a processing module based upon a determination that the processing module from which data objects are being reassigned is classified as a straggler. 19 . A method according to claim 11 , wherein the method is performed by a computer having a memory executing one or more program of instructions which are tangibly embodied in a storage medium readable by the computer. 20 . A method for a processing module iteratively processing data objects based upon a database query, the method comprising: requesting one or more data objects from a control task module; receiving one or more data objects that have been iteratively dynamically assigned to the processing module by the control task module; executing a step for the assigned one or more data objects; providing processing activity information associated with the processing module to the control task module; and repeating requesting of data objects from the control task module and providing processing activity information to the control task module until end of data stream associated with the database query. 21 . A method according to claim 20 , wherein receiving one or more data objects that have been iteratively dynamically assigned to the processing module by the control task module includes: receiving only

Assignees

Inventors

Classifications

  • Plan optimisation · CPC title

  • G06F9/5027Primary

    the resource being a machine, e.g. CPUs, Servers, Terminals · CPC title

  • G06F9/505Primary

    considering the load · CPC title

  • Query optimisation · CPC title

  • Hypervisor-specific management and integration aspects · 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 US2020201680A1 cover?
A database system comprises a plurality of processing modules arranged to process data objects from a plurality of data object servers based upon a database query from a client computer system. A control task module is arranged to iteratively dynamically assign data objects from the plurality of data object servers to each of the plurality of processing modules based upon processing activity as…
Who is the assignee on this patent?
Teradata Us Inc
What technology area does this patent fall under?
Primary CPC classification G06F9/5027. Mapped technology areas include Physics.
When was this patent published?
Publication date Thu Jun 25 2020 00:00:00 GMT+0000 (Coordinated Universal Time) (A1). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 1 related publication on this page (citations in our corpus or others sharing the same primary CPC).