跳到主要内容

共享包和示例

Prisma 制作的扩展

以下是我们在 Prisma 构建的扩展列表

扩展描述
@prisma/extension-accelerate启用 Accelerate,一个全局数据库缓存,在 300 多个地点可用,并内置连接池
@prisma/extension-read-replicas为 Prisma Client 添加只读副本支持

Prisma 社区制作的扩展

以下是由社区创建的扩展列表。 如果你想创建你自己的包,请参考 共享 Prisma Client 扩展 文档。

扩展描述
prisma-extension-supabase-rls为 Prisma 添加 Supabase 行级安全支持
prisma-extension-bark实现物化路径模式,允许你在 Prisma 中轻松创建和交互树状结构
prisma-cursorstream添加基于游标的流式处理
prisma-gpt允许你使用自然语言查询你的数据库
prisma-extension-caching添加缓存复杂查询的能力
prisma-extension-cache-manager使用任何 cache-manager 兼容的缓存来缓存模型查询
prisma-extension-random允许你查询数据库中的随机行
prisma-paginate添加分页读取查询的支持
prisma-extension-streamdal添加使用 Streamdal 的代码原生数据管道支持
prisma-rbac添加可自定义的基于角色的访问控制
prisma-extension-redis广泛的 Prisma 扩展,旨在利用 Redis 和 Dragonfly 数据库实现高效的缓存和缓存失效
prisma-cache-extension用于使用 Redis 缓存和使缓存失效的 Prisma 扩展(将支持其他存储选项)
prisma-extension-caslPrisma 客户端扩展,利用 CASL 在大多数简单和嵌套查询上强制执行授权逻辑。

如果你已经构建了一个扩展并希望看到它被推荐,请随时通过打开 pull request 将其添加到列表中。

示例

信息

以下示例扩展仅作为示例提供,不提供任何保证。 它们旨在展示如何使用此处记录的方法创建 Prisma Client 扩展。 我们建议使用这些示例作为构建你自己的扩展的灵感来源。

示例描述
audit-log-context将当前用户的 ID 作为上下文提供给 Postgres 审计日志触发器
callback-free-itx添加一个无需回调即可启动交互式事务的方法
computed-fields向结果对象添加虚拟/计算字段
input-transformation转换传递给 Prisma Client 查询的输入参数以过滤结果集
input-validation对传递给 mutation 方法的输入参数运行自定义验证逻辑
instance-methods向结果对象添加类似 Active Record 的方法,如 `save()` 和 `delete()`
json-field-types对存储在 JSON 列中的数据使用强类型运行时解析
model-filters添加可重用的过滤器,可以组合成模型的复杂 `where` 条件
obfuscated-fields防止敏感数据(例如 `password` 字段)包含在结果中
query-logging用简单的查询计时和日志记录包装 Prisma Client 查询
readonly-client创建一个仅允许读取操作的客户端
retry-transactions为事务添加具有指数退避和抖动的重试机制
row-level-security使用 Postgres 行级安全策略来隔离多租户应用程序的数据
static-methods向 Prisma Client 模型添加自定义查询方法
transformed-fields演示如何使用结果扩展来转换查询结果并向应用添加 i18n
exists-method演示如何向所有模型添加 `exists` 方法
update-delete-ignore-not-found演示如何向所有模型添加 `updateIgnoreOnNotFound` 和 `deleteIgnoreOnNotFound` 方法。

更进一步