查询性能

谈到 Drizzle — 我们是一个薄薄的 TypeScript 层,位于 SQL 之上,几乎没有开销, 为了使其真正达到 0,您可以利用我们的预编译语句 API。

当您在数据库上运行查询时,会发生几件事:

通过预编译语句,您只需在 Drizzle ORM 端进行一次 SQL 连接, 然后数据库驱动程序就能够重用预编译的二进制 SQL,而不是每次都解析查询。 这在处理大型 SQL 查询时具有极大的性能优势。

不同的数据库驱动程序以不同的方式支持预编译语句,有时 Drizzle ORM 可以比 更好的 sqlite3 驱动程序更快。

预编译语句

PostgreSQL
MySQL
SQLite
SingleStore
const db = drizzle(...);

const prepared = db.select().from(customers).prepare("statement_name");

const res1 = await prepared.execute();
const res2 = await prepared.execute();
const res3 = await prepared.execute();

占位符

每当您需要嵌入动态运行时值时 - 您可以使用 sql.placeholder(...) API

PostgreSQL
MySQL
SQLite
SingleStore
import { sql } from "drizzle-orm";

const p1 = db
  .select()
  .from(customers)
  .where(eq(customers.id, sql.placeholder('id')))
  .prepare("p1")

await p1.execute({ id: 10 }) // SELECT * FROM customers WHERE id = 10
await p1.execute({ id: 12 }) // SELECT * FROM customers WHERE id = 12

const p2 = db
  .select()
  .from(customers)
  .where(sql`lower(${customers.name}) like ${sql.placeholder('name')}`)
  .prepare("p2");

await p2.execute({ name: '%an%' }) // SELECT * FROM customers WHERE name ilike '%an%'