data:image/s3,"s3://crabby-images/d2d61/d2d61833bf4246f972c258dbbf5a41485bf82fea" alt="Dave Dave"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Dec 27, 2021 12:12 PM
I have a script that calls an API and writes the JSON objects to my table. This has hit the limit of what I know about scripting.
Can anyone help modify my script so that on the next call, it will update any records that exist and insert any records that are new.
I assume I need an IF statement to look for an existing ID and validate if the associated string matches ELSE create a new record.
My existing script is:
let response = await remoteFetchAsync(“APIURL”, requestOptions);
let json = await response.json();
let table = base.getTable(“Titles”);
for (i=0; i < json.length; i++) {
let recordId = await table.createRecordAsync({
“Title”: json[i].Title,
“ID”: json[i].ID
})
};
Thanks!
data:image/s3,"s3://crabby-images/56681/566811218c571b16b48acc8ee7c884e1a2c9f943" alt="Justin_Barrett Justin_Barrett"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Dec 29, 2021 10:26 AM
Welcome to the community, @Dave! :grinning_face_with_big_eyes: Here are a couple of tips that should get you a little further (if you haven’t already solved this).
First, I recommend switching your looping mechanism to use the for...of
syntax:
for (let item of json) {
...
Then you would access properties of the item like this: item.Title
. Unless there’s a need to use the index of the item in the original array, this is a more streamlined approach.
You’re definitely thinking in the right direction. I recommend looking into the find()
array method, and using that to locate a matching record from the [Titles]
table. If found, do what you want with the matching record; otherwise create a new one.
data:image/s3,"s3://crabby-images/8cb2f/8cb2f3bec7aa3b8b55da0b6eb8d1d81194430375" alt=""