update multiple fields

Hi is there a other way to update multiple fields currently i do it like this
const updatePollOption = (option: PollOptionsSchema) => {
const { isNew, id, ...options } = option;
return db
.update(tables.pollOptions)
.set({ ...options, pollId: pollId })
.where(eq(tables.pollOptions.id, option.id));
};

const result = await Promise.all(
pollOptions.map((option) => updatePollOption(option))
);
const updatePollOption = (option: PollOptionsSchema) => {
const { isNew, id, ...options } = option;
return db
.update(tables.pollOptions)
.set({ ...options, pollId: pollId })
.where(eq(tables.pollOptions.id, option.id));
};

const result = await Promise.all(
pollOptions.map((option) => updatePollOption(option))
);
9 Replies
MAST
MASTβ€’2y ago
You can pass an array to the set if I remember it correctly.
πŸ‡¨πŸ‡­ Marko Bolliger <cannap>
yes but i have diffet idΒ΄s
rphlmr ⚑
rphlmr βš‘β€’2y ago
Maybe do that in a transaction if you are concerned about consistency (all or nothing). This code is πŸ‘ until you have hundreds poll options. (Batch update)
Angelelz
Angelelzβ€’2y ago
How would you do that in SQL? I like Drizzle bacause it doesn't abstract away too much, very close to sql and type safe If you want to update different rows in SQL with different data, you need to write different queries, right?
Angelelz
Angelelzβ€’2y ago
@Raphaël M (@rphlmr) ⚑ is right then. As long as you're not updating a whole lot of rows. I would do it in a transaction just to be safe, remember that Promise.all is not great if some of your promises reject. Maybe use Promise.allSettle So you know what rejected and what worked
ivanfeliciano
ivanfelicianoβ€’2y ago
Like so:
db
.insert(table)
.values(array)
.onConflictDoUpdate({
target: table.id,
set: {
field: sql`excluded.field`,
},
})
db
.insert(table)
.values(array)
.onConflictDoUpdate({
target: table.id,
set: {
field: sql`excluded.field`,
},
})
I believe you will have to explicitly put all the columns in the set: {}
Angelelz
Angelelzβ€’2y ago
This is a great way!
Andrii Sherman
Andrii Shermanβ€’2y ago
We will also make an excluded object available in callback, so you'll have a native suppoort for it

Did you find this page helpful?