跳到主要内容

共享包和示例

Prisma 制作的扩展

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

扩展描述
@prisma/extension-accelerate启用 Accelerate,一个全球数据库缓存,在 300 多个地点可用,并内置连接池
@prisma/extension-pulse启用 Pulse,一项从您的数据库捕获更改事件并立即将其传递到您的应用程序的服务。
@prisma/extension-read-replicas向 Prisma Client 添加读取副本支持

Prisma 社区制作的扩展

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

扩展描述
prisma-extension-supabase-rls添加对 Supabase 行级安全与 Prisma 的支持
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 在大多数简单和嵌套查询上强制执行授权逻辑。

如果您构建了一个扩展并希望看到它被收录,请随时通过打开拉取请求将其添加到列表中。

示例

信息

以下示例扩展仅作为示例提供,不提供任何保证。它们旨在展示如何使用此处记录的方法创建 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演示如何向所有模型添加 updateIgnoreOnNotFounddeleteIgnoreOnNotFound 方法。

更进一步