Hapi 开发人员的完美 ORM

使用 Prisma(一个更优秀的 JavaScript 和 TypeScript ORM)在 Hapi 应用中查询 MySQL、PostgreSQL 和 SQL Server 数据库中的数据。

tech

什么是 Prisma?

Prisma 使数据操作变得简单!它提供了一个类型安全的 Node.js & TypeScript ORM,全局数据库缓存,连接池以及实时数据库事件。

查询
// Creating a new record
await prisma.user.create({
firstName: “Alice”,
email: “alice@prisma.io”
})
表格
id firstName email
1 Bobby bobby@tables.io
2 Nilufar nilu@email.com
3 Jürgen jums@dums.edu
4 Alice alice@prisma.io

Prisma 和 Hapi 如何协同工作

Prisma 是一款新一代 ORM,用于在 Hapi 应用中查询数据库。您可以将其用作编写纯 SQL 查询的替代方案,或替代 knex.js 等查询构建器或 TypeORM、MikroORM 和 Sequelize 等传统 ORM。

虽然 Prisma 与 Hapi 配合使用效果很好,但您也可以将其与其他任何 Web 框架(如 Koa.js、Fastify 或 FeathersJS)一起使用。Prisma 可用于构建 RESTGraphQL API,并与微服务和单体架构无缝集成。

Prisma 和 Hapi 的用例

Prisma 提供了一个方便的数据库访问层,可以完美地与 Hapi 集成。

以下代码演示了在使用 Hapi 构建 API 服务器时 Prisma 的各种用法。

prismaPlugin

prismaPlugin

prismaPlugin 是特定于领域或模型的插件的基础。它包含的 PrismaClient 实例为应用程序的其余部分提供了数据库接口。

1import { PrismaClient } from '@prisma/client'
2import Hapi from '@hapi/hapi'
3
4declare module '@hapi/hapi' {
5 interface ServerApplicationState {
6 prisma: PrismaClient
7 }
8}
9
10const prismaPlugin = {
11 name: 'prisma',
12 register: async function(server) {
13 const prisma = new PrismaClient()
14
15 server.app.prisma = prisma
16
17 server.ext({
18 type: 'onPostStop',
19 method: async (server) => {
20 server.app.prisma.$disconnect()
21 },
22 })
23 },
24}
25
26export default prismaPlugin
usersPlugin
Prisma 模式

prismaPlugin

prismaPlugin 是特定于领域或模型的插件的基础。它包含的 PrismaClient 实例为应用程序的其余部分提供了数据库接口。

1import { PrismaClient } from '@prisma/client'
2import Hapi from '@hapi/hapi'
3
4declare module '@hapi/hapi' {
5 interface ServerApplicationState {
6 prisma: PrismaClient
7 }
8}
9
10const prismaPlugin = {
11 name: 'prisma',
12 register: async function(server) {
13 const prisma = new PrismaClient()
14
15 server.app.prisma = prisma
16
17 server.ext({
18 type: 'onPostStop',
19 method: async (server) => {
20 server.app.prisma.$disconnect()
21 },
22 })
23 },
24}
25
26export default prismaPlugin

为什么选择 Prisma 和 Hapi?

无缝集成

无论您是构建 REST 还是 GraphQL API,Prisma 都可以完美地融入 Hapi 的灵活架构。

更高的生产力

Prisma 为您提供数据库查询的自动完成、出色的开发体验和完整的类型安全性。

类型安全的数据库客户端

Prisma Client 确保完全类型安全的数据库查询,并具有自动完成等优势 - 即使在 JavaScript 中也是如此。

直观的 数据建模

Prisma 的声明式建模语言简单易用,让您可以直观地描述数据库模式。

轻松的数据库迁移

从声明式 Prisma 模式生成可预测且可自定义的 SQL 迁移。

专为构建 API 而设计

Prisma Client 通过为常见 API 功能(例如分页、过滤器等)提供查询来减少样板代码。

精选的 Prisma & Hapi 示例

使用 TypeScript、PostgreSQL 和 Prisma 构建现代后端

使用 Hapi 和 Prisma 构建现代后端的教程系列

REST API 入门套件

一个使用 SQLite 数据库的 REST API 的即用型示例项目

GraphQL API 入门套件

一个使用 SQLite 数据库的 GraphQL API 的即用型示例项目