Help

Airtable API and preventing concurrent modification

829 3
cancel
Showing results for 
Search instead for 
Did you mean: 
TimothyMDean
4 - Data Explorer
4 - Data Explorer

I am looking into the possibility of using AirTable as a back end data repository for some of our data. In order for this to work, I'd have various event triggers accepting data fields and using that data to create or update an Airtable base/table using REST API calls. The goal is to replace some existing back-end that is stored in a SQL Server database.

One aspect that I'm not sure to handle is preventing concurrent changes. If, for example, I have multiple changes happening to a record that could possibly be processed at near the same time, I need to make sure that the newest value "wins".

The way this works in the current service is as follows:

  1. Before sending an updated value to the back-end via its API, a service gets the current value and compares the current value to the new value and only calls the API if one or more fields changed
  2. As part of getting the current version, the service gets the version value of the row (implemented as a rowversion in the SQL database, but I've seen similar version/revision in many other REST APIs)
  3. When a field has changed, the update gets sent to the back-end along with the row version
  4. The back-end rejects the update if the version in the request is NOT the current version. In other words, if someone else came in and update the field AFTER the current values were retrieved, but BEFORE the update was received, then the update will fail with a error that denotes version conflict (e.g. HTTP 409)
  5. In the event of a conflict error, the client needs to re-retrieve the current version of the record, and again do its checks to see if there was an update. If there is still an update to make, it can then retry the update with the new version.

I realize that Airtable doesn't have direct analogs to everything that can be done with a SQL database. I'm wondering what the best practice would be with the Airtable API if I want to manage concurrent modification scenarios like this one. 

3 Replies 3

Hello @TimothyMDean,
First, read this https://support.airtable.com/docs/managing-api-call-limits-in-airtable#:~:text=Airtable%20enforces%2....

Then read this https://airtable.com/developers/web/api/errors

If you still has issues about how those ratelimit and errors are works. then comeback again with screenshots and request information.

👍

TimothyMDean
4 - Data Explorer
4 - Data Explorer

@dilipborad Sorry - those links don't answer my question. This isn't a rate limit issue, it's a question about how possible concurrency issues are handled by the API.

benhuangbmj
4 - Data Explorer
4 - Data Explorer

I have a very similar question. Does Airtable have any race condition prevention mechanics in place? Suppose I have an automation that run a script to modify the data in a record, is it possible to trigger two instances of this automation at once? Since JavaScript in general may entail race condition, I suspect that this needs some caution. Thanks.