0

0

Prisma 中 Decimal 字段的序列化行为解析与优雅处理方案

心靈之曲

心靈之曲

发布时间:2026-02-13 17:19:11

|

918人浏览过

|

来源于php中文网

原创

Prisma 中 Decimal 字段的序列化行为解析与优雅处理方案

Prisma 使用 Decimal.js 处理 @db.Decimal 类型,导致查询结果返回包含 s(符号)、e(指数)、d(数字数组)的对象结构;本文详解其成因,并提供安全转换为原生 JavaScript 数字或字符串的实用方案。

prisma 使用 decimal.js 处理 `@db.decimal` 类型,导致查询结果返回包含 `s`(符号)、`e`(指数)、`d`(数字数组)的对象结构;本文详解其成因,并提供安全转换为原生 javascript 数字或字符串的实用方案。

在 Prisma 中定义高精度数值字段时,开发者常使用 @db.Decimal(p, s)(如 @db.Decimal(7, 4))以确保数据库层面的精确小数存储。然而,当通过 Prisma Client 查询该字段时,返回值并非原始数字(如 1.2345),而是一个形如 { s: 1, e: 0, d: [1, 2, 3, 4, 5] } 的对象——这是 Prisma 内部基于 Decimal.js 的序列化表示,其中:

  • s:符号位(1 表示正数,-1 表示负数)
  • e:十进制指数(即小数点偏移量)
  • d:数字数组(不含前导零,按高位到低位排列)

⚠️ 重要提示:这不是“bug”,而是 Prisma 为保障数值精度而采取的主动设计。直接忽略 s 和 e 并仅拼接 d 数组会导致严重精度错误(例如 e = -3 时实际值为 0.00123,而非 123)。

✅ 正确转换方式:使用 Decimal.js 实例方法

Prisma 返回的 Decimal 对象是 Decimal.js 的实例(已内置,无需额外安装),可安全调用其方法:

醒蓝AI
醒蓝AI

一键快速生成Al形象照、证件照、写真照的强大AI换脸软件

下载
import { PrismaClient } from '@prisma/client';
const prisma = new PrismaClient();

// 查询示例
const record = await prisma.product.findUnique({
  where: { id: 1 },
  select: { value: true },
});

console.log(record.value); 
// → { s: 1, e: -2, d: [1, 2, 3] }  // 表示 1.23

// ✅ 推荐:转为字符串(保留全部精度,无浮点误差)
const valueStr = record.value.toString(); // "1.23"

// ✅ 安全转为 number(仅当确认精度可接受时使用)
const valueNum = record.value.toNumber(); // 1.23

// ✅ 转为固定小数位字符串(如用于展示)
const formatted = record.value.toFixed(4); // "1.2300"

⚠️ 不推荐的做法及风险

  • ❌ parseFloat(JSON.stringify(record.value)):不可靠,JSON.stringify() 会丢失 s/e/d 结构语义,结果未定义。
  • ❌ 手动拼接 d 数组 + 忽略 e:完全破坏数值含义,例如 { e: -4, d: [9, 9, 9] } 应为 0.000999,而非 999。
  • ❌ 直接替换为 Float 类型:虽可返回原生数字,但会引入 IEEE 754 浮点误差(如 0.1 + 0.2 !== 0.3),丧失 Decimal 设计初衷——适用于金融、计量等精度敏感场景。

? 最佳实践建议

  1. 读取时统一转换:在业务逻辑层或 DTO 转换器中封装转换逻辑,避免重复代码:

    const toSafeNumber = (dec: Decimal | null) => dec?.toNumber() ?? null;
    const toFixedString = (dec: Decimal | null, digits = 2) => dec?.toFixed(digits) ?? '0';
  2. 写入时仍用 Decimal 构造:创建/更新时传入字符串或数字(Prisma 自动转换):

    await prisma.product.create({
      data: { value: '123.4567' }, // ✅ 推荐:字符串,避免 JS 浮点污染
      // 或 { value: 123.4567 }     // ⚠️ 可用,但需注意 JS number 本身可能不精确
    });
  3. 类型安全增强(TypeScript):
    在 Prisma 客户端生成后,可通过声明合并扩展类型,明确标注 Decimal 字段:

    declare module '@prisma/client' {
      interface Product {
        value: Decimal; // 显式类型,提升 IDE 提示与编译检查
      }
    }

总结:Prisma 的 Decimal 返回结构是精度保障机制的体现,而非冗余信息。拥抱 Decimal.js API,而非规避它——这既是正确做法,也是金融级应用稳健性的基石。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

9

2026.02.13

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

436

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

317

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

587

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

104

2025.10.23

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

530

2023.08.03

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

23

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号