9672266

Method and Apparatus for Ensuring Consistent Outcomes in Updates to Distributed Databases

PublishedJune 6, 2017
Assigneenot available in USPTO data we have
Technical Abstract

Patent Claims
14 claims

Legal claims defining the scope of protection, as filed with the USPTO.

1

1. A method of updating a database, comprising: receiving data to be written to a database; identifying a set of shard replicas corresponding to the database to which the data is to be written; transmitting, to each of the replicas in the set, a request to write the data thereto; receiving votes back from the replicas in the set, each vote representing whether the respective replica commits to a writing of the data thereto; determining whether to commit to the writing of the data to the database according to whether, for each shard having replicas in the set, a majority but less than all of the replicas of the each shard which also belong to the set has transmitted a vote committing to the writing of the data thereto; if at least one of the shards having replica in the set fails to achieve the majority but less than all of the replica, not committing the writing; and transmitting an outcome of the determining to each of the replicas in the set.

2

2. The method of claim 1 , wherein the transmitting an outcome further comprises transmitting a commit instruction to each of the replicas in the set upon receiving the vote committing to the writing of the data from, for each shard having replicas in the set, a majority of the replicas of that shard which also belong to the set.

3

3. The method of claim 1 , wherein the transmitting an outcome further comprises transmitting a cancel instruction to each of the replicas in the set upon receiving votes committing to the writing of the data from less than half of the replicas of a shard having replicas in the set after a predetermined time period.

4

4. The method of claim 1 , wherein the transmitting, to each of the replicas in the set, a request to write the data thereto further comprises transmitting at least a portion of the data that is to be written.

5

5. A method of updating a database, comprising transmitting a request to execute a database transaction, the request transmitted to a set of database members, the set being a set of shard replicas; receiving responses from the members of the set, each response representing whether the corresponding member commits to the transaction; committing to the transaction if, for each shard having replicas in the set, a majority but less than all of its respective replicas of the set of shard replicas has committed to the transaction; and if at least one of the shards having replica in the set fails to achieve the majority but less than all of the replica, not committing the writing.

6

6. The method of claim 5 , further comprising cancelling the transaction if, for at least one shard having replicas in the set, only a minority of its respective replicas has transmitted a response representing commitment to the transaction after a predetermined time period.

7

7. The method of claim 5 , wherein the transmitting a request further comprises transmitting data to be written to the database in the transaction.

8

8. One or more non-transitory computer-readable media, the memories collectively storing instructions for executing a method of updating a database, the method comprising: receiving data to be written to a database; identifying a set of shard replicas corresponding to the database to which the data is to be written; transmitting, to each of the replicas in the set, a request to write the data thereto; receiving votes back from the replicas in the set, each vote representing whether the respective shard or replica commits to a writing of the data thereto; determining whether to commit to the writing of the data to the database according to whether, for each shard having replicas in the set, a majority but less than all of the replicas of the each shard which also belong to the set has transmitted a vote committing to the writing of the data thereto; if at least one of the shards having replica in the set fails to achieve the majority but less than all of the replica, not committing the writing; and transmitting an outcome of the determining to each of the replicas in the set.

9

9. The one or more non-transitory computer-readable media of claim 8 , wherein the transmitting an outcome further comprises transmitting a commit instruction to each of the replicas in the set upon receiving the vote committing to the writing of the data from, for each shard having replicas in the set, a majority of the replicas of that shard which also belong to the set.

10

10. The one or more non-transitory computer-readable media of claim 8 , wherein the transmitting an outcome further comprises transmitting a cancel instruction to each of the replicas in the set upon receiving votes committing to the writing of the data from less than half of the replicas of a shard having replicas in the set after a predetermined time period.

11

11. The one or more non-transitory computer-readable media of claim 8 , wherein the transmitting, to each of the shards and the replicas in the set, a request to write the data thereto further comprises transmitting at least a portion of the data that is to be written.

12

12. One or more non-transitory computer-readable media, the memories collectively storing instructions for executing a method of updating a database, the method comprising: transmitting a request to execute a database transaction, the request transmitted to a set of database members, the set being a set of shard replicas; receiving responses from the members of the set, each response representing whether the corresponding member commits to the transaction; committing to the transaction if, for each shard having replicas in the set, a majority but less than all of its respective replicas of the set of shard replicas has committed to the transaction; and if at least one of the shards having replica in the set fails to achieve the majority but less than all of the replica, not committing the writing.

13

13. The one or more non-transitory computer-readable media of claim 12 , further comprising cancelling the transaction if, for at least one shard having replicas in the set, only a minority of its respective replicas has transmitted a response representing commitment to the transaction after a predetermined time period.

14

14. The one or more non-transitory computer-readable media of claim 12 , wherein the transmitting a request further comprises transmitting data to be written to the database in the transaction.

Patent Metadata

Filing Date

Unknown

Publication Date

June 6, 2017

Inventors

James WEBBER
Ian S. ROBINSON
Mats Tobias LINDAAKER
Alistair Philip Campbell JONES

Want to explore more patents?

Browse 5M+ US patents with plain-English claim translations and AI-generated analysis.

Citation & reuse

Analysis on this page is generated by Patentable — an AI-powered patent intelligence platform. AI-generated summaries, explanations, and analysis may be reused with attribution and a visible link back to the canonical URL below. Patent abstracts and claims are USPTO public domain.

Cite as: Patentable. “METHOD AND APPARATUS FOR ENSURING CONSISTENT OUTCOMES IN UPDATES TO DISTRIBUTED DATABASES” (9672266). https://patentable.app/patents/9672266

© 2026 Patentable. All rights reserved.

Patentable is a research and drafting-assistant tool, not a law firm, and does not provide legal advice. Documents we generate are drafts for review by a licensed patent attorney.

METHOD AND APPARATUS FOR ENSURING CONSISTENT OUTCOMES IN UPDATES TO DISTRIBUTED DATABASES — James WEBBER | Patentable