跳至主要内容

共享包和示例

Prisma 制造的扩展

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

扩展描述
@prisma/extension-accelerate启用 Accelerate,一个在 300 多个地点提供的全局数据库缓存,具有内置连接池
@prisma/extension-pulse启用 Pulse,一项从您的数据库捕获更改事件并将其即时传递到您的应用程序的服务。
@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专为使用 Redis 和 Dragonfly 数据库进行高效缓存和缓存失效而设计的扩展 Prisma 扩展
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对传递给变异方法的输入参数运行自定义验证逻辑
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 方法。

更进一步