首页
/ Drizzle ORM 处理 PostgreSQL 中 LOCALTIMESTAMP 默认值的正确方式

Drizzle ORM 处理 PostgreSQL 中 LOCALTIMESTAMP 默认值的正确方式

2025-05-06 17:00:32作者:秋泉律Samson

在数据库开发中,为时间戳字段设置默认值是一个常见需求。PostgreSQL 提供了标准的 SQL 函数 LOCALTIMESTAMP 来获取当前时间戳,但如何在 Drizzle ORM 中正确处理这一默认值呢?

问题背景

当使用 Drizzle ORM 的 introspection 功能从 PostgreSQL 数据库生成模式定义时,如果表中有使用 LOCALTIMESTAMP 作为默认值的字段,生成的模式文件会出现问题。具体表现为:

  1. 原始 SQL 表定义:
CREATE TABLE test (
  test TIMESTAMP WITHOUT TIME ZONE DEFAULT LOCALTIMESTAMP
);
  1. 生成的模式文件:
export const test = pgTable("test", {
  test: timestamp({ mode: 'string' }).default(LOCALTIMESTAMP),
});
  1. 尝试推送此模式时会出现错误:
ReferenceError: LOCALTIMESTAMP is not defined

解决方案

正确的做法是使用 Drizzle ORM 提供的 sql 标签来包装 PostgreSQL 函数调用:

test: timestamp({ mode: 'string' }).default(sql`LOCALTIMESTAMP`),

技术原理

Drizzle ORM 需要明确区分 JavaScript 运行时环境和 SQL 表达式。LOCALTIMESTAMP 是一个 SQL 函数,而不是 JavaScript 变量或函数。通过使用 sql 标签,我们告诉 Drizzle 这是一个需要原样传递到 SQL 查询中的表达式,而不是在 JavaScript 环境中求值的代码。

最佳实践

  1. 对于所有 PostgreSQL 内置函数作为默认值的情况,都应使用 sql 标签
  2. 在手动编写模式定义时,注意区分 JavaScript 和 SQL 上下文
  3. 定期更新 Drizzle ORM 和相关工具,以确保获得最新的修复和改进

版本说明

这个问题在 Drizzle ORM 0.37 和 Drizzle Kit 0.29 版本中已得到修复。新版本能够正确识别 LOCALTIMESTAMP 等 SQL 函数,并在生成的模式文件中自动添加 sql 标签。

通过理解这一机制,开发者可以更好地处理数据库模式与 ORM 之间的映射关系,避免类似的引用错误问题。

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

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
177
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
864
512
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
261
302
kernelkernel
deepin linux kernel
C
22
5
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
596
57
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K