首页
/ Drizzle ORM 中 SQLite 表定义方式的变更解析

Drizzle ORM 中 SQLite 表定义方式的变更解析

2025-05-06 03:18:50作者:咎岭娴Homer

Drizzle ORM 是一个现代化的 TypeScript ORM 框架,近期在其 0.38.x 版本中对 SQLite 表定义方式进行了重要变更。这一变更主要涉及 sqliteTable 函数的第三个参数类型,从对象(object)改为数组(array)。

变更背景

在 Drizzle ORM 的早期版本中,定义 SQLite 表时通常使用如下语法:

export const comments = sqliteTable('comments', {
  id: integer().primaryKey({ autoIncrement: true }),
  text: text({ length: 256 }),
  postId: integer('post_id'),
  ownerId: integer('owner_id')
});

或者带有第三个回调参数的版本:

export const comments = sqliteTable(
  'comments',
  {
    id: integer().primaryKey({ autoIncrement: true }),
    text: text({ length: 256 }),
    postId: integer('post_id'),
    ownerId: integer('owner_id')
  },
  (t) => ({ /* 索引和约束定义 */ })
);

变更内容

从 Drizzle ORM 0.38.0 版本开始,开发团队对 sqliteTable 函数的第三个参数进行了调整:

  1. 现在强烈建议为所有表定义提供第三个参数
  2. 第三个参数的回调函数返回值类型从对象改为数组

新的推荐写法如下:

export const comments = sqliteTable(
  'comments',
  {
    id: integer().primaryKey({ autoIncrement: true }),
    text: text({ length: 256 }),
    postId: integer('post_id'),
    ownerId: integer('owner_id')
  },
  (t) => [] // 返回数组而非对象
);

变更原因

这一变更主要是为了:

  1. 统一不同数据库方言的 API 设计
  2. 简化类型系统处理
  3. 为未来功能扩展提供更灵活的基础

值得注意的是,PostgreSQL 方言早已采用数组作为回调返回值,此次变更使 SQLite 与其保持一致。

迁移建议

对于现有项目,建议采取以下步骤进行迁移:

  1. 升级到 Drizzle ORM 0.38.3 或更高版本
  2. 为所有表定义添加第三个参数
  3. 将回调返回值从对象形式改为数组形式
  4. 运行类型检查确保没有遗漏

常见问题

  1. 为什么升级后仍然看到警告? 请确认是否已升级到 0.38.3 或更高版本,并确保回调返回的是数组而非对象。

  2. 文档和实现不一致怎么办? 目前官方文档可能尚未完全更新,建议以实际代码行为和类型提示为准。

  3. 这一变更会影响现有功能吗? 不会影响现有功能,但会改善类型推断和未来兼容性。

这一变更是 Drizzle ORM 持续优化的一部分,虽然短期内可能需要开发者进行一些调整,但从长远来看将带来更一致和可靠的开发体验。

登录后查看全文
热门项目推荐
相关项目推荐