Drizzle | SQL 递减值
PostgreSQL
MySQL
SQLite
本指南假定您熟悉

要递减列值,可以使用 update().set() 方法,如下所示:

import { eq, sql } from 'drizzle-orm';

const db = drizzle(...)
  
await db
  .update(table)
  .set({
    counter: sql`${table.counter} - 1`,
  })
  .where(eq(table.id, 1));
update "table" set "counter" = "counter" - 1 where "id" = 1;

Drizzle 具有简单灵活的 API,可让您轻松创建自定义解决方案。这是您实现自定义递减函数的方法。

import { AnyColumn } from 'drizzle-orm';

const decrement = (column: AnyColumn, value = 1) => {
  return sql`${column} - ${value}`;
};

await db
  .update(table)
  .set({
    counter1: decrement(table.counter1),
    counter2: decrement(table.counter2, 10),
  })
  .where(eq(table.id, 1));