在传统的后端 API 开发中,开发者需要自行编写数据库查询、定义数据类型及其关系以及 API 接口。而 GraphQL 和 Prisma 的出现,则可简化这 一过程。GraphQL 是一种用于 API 的查询语言,而 Prisma 可以帮助我们管理数据模型。
因此,这篇文章主要介绍如何使用 GraphQL 和 Prisma 实现后端 API。我们将通过以下步骤逐一实现:
- 创建 Prisma 数据模型
- 创建 GraphQL schema 和 resolver
- 将 GraphQL API 与 Prisma 数据库集成
- 使用 Prisma 客户端进行数据库操作
前置条件:
- 已经安装 Node.js 和 npm。
- 具备基础的 JavaScript 和 GraphQL 知识。
1. 创建 Prisma 数据模型
首先我们需要安装 Prisma。在命令行中输入:
npm install prisma --save-dev
接下来,在项目根目录下运行以下命令生成 Prisma 配置文件和数据模型文件:
npx prisma init
这个命令会自动生成一个 prisma
目录和相应的文件,如图所示:
现在,我们需要打开 prisma/schema.prisma
文件,并定义我们的数据模型。假设我们需要管理学生和教师信息,我们可以这样来定义:
-- -------------------- ---- ------- ------- ---------- -- - -------- - ------------ --- - -------------------------------------------------------------------- - ----- ------- - -- --- --- ------------------------- ---- ------ --- --- --- ----- ----- ------- - ----- ------- - -- --- --- ------------------------- ---- ------ --- --- ----- ------- -
这里,我们定义了一个 db
数据源,可以指向我们的 PostgreSQL 数据库。在本例中,假设我们使用的是本地的 PostgreSQL 数据库,端口为 5432
,数据库名字为 mydatabase
。
我们还定义了两个模型:Student
和 Teacher
。其中,Student
模型有 id
、name
、age
、gpa
和 major
字段,Teacher
模型有 id
、name
、age
和 title
字段。
现在,我们需要在命令行中运行以下命令来同步 Prisma 数据模型到数据库中:
npx prisma db push
这个命令将自动创建数据库表和字段,并将 Prisma 数据模型同步到数据库中。
2. 创建 GraphQL schema 和 resolver
接下来,我们需要定义一个 GraphQL schema 和 resolver 来实现我们的业务逻辑。我们需要先安装 graphql
和 apollo-server
。
npm install graphql apollo-server --save-dev
然后在项目根目录中创建以下三个文件:
. ├── src/ │ ├── schema.graphql │ ├── resolvers.js │ └── index.js └── package.json
schema.graphql
:定义 GraphQL schema。resolvers.js
:定义 resolver 函数。index.js
:开启 Apollo Server。
我们需要在 schema.graphql
中定义我们的 GraphQL schema。对于我们的学生和教师信息管理业务,我们可以这样定义:
-- -------------------- ---- ------- ---- ------- - --- ---- ----- ------- ---- ---- ---- ------ ------ ------ - ---- ------- - --- ---- ----- ------- ---- ---- ------ ------ - ---- ----- - --------- ---------- ----------- ------ ------- --------- ---------- ----------- ------ ------- - ---- -------- - ------------------- -------- ---- ----- ---- ------- ------ -------- -------- ----------------- ----- ----- ------- ---- ---- ---- ------ ------ -------- -------- ----------------- ------ -------- ------------------- -------- ---- ----- ------ -------- -------- ----------------- ----- ----- ------- ---- ---- ------ -------- -------- ----------------- ------ -------- -
这里,我们定义了两个类型:Student
和 Teacher
,分别对应我们的数据模型。对于查询,我们定义了 Query
类型,其中包括 students
、student
、teachers
和 teacher
四个字段。对于 CRUD 操作,我们定义了 Mutation
类型,其中包括 createStudent
、updateStudent
、deleteStudent
、createTeacher
、updateTeacher
和 deleteTeacher
六个字段。
接下来,我们需要在 resolvers.js
文件中定义 resolver 函数。我们可以按照以下方式定义:
-- -------------------- ---- ------- ----- - ------------ - - ------------------------- ----- ------ - --- -------------- ----- --------- - - ------ - --------- -- -- - ------ ------------------------- -- -------- ------ - -- -- -- - ------ --------------------------- ------ - --- -- - -- -- --------- -- -- - ------ ------------------------- -- -------- ------ - -- -- -- - ------ --------------------------- ------ - --- -- - -- -- -- --------- - -------------- ------ ----- -- - ----- - ----- ---- ---- ----- - - ---- ------ ----------------------- ----- - ----- ---- ---- ----- - -- -- -------------- ------ ----- -- - ----- - --- ----- ---- ---- ----- - - ---- ------ ----------------------- ------ - -- -- ----- - ----- ---- ---- ----- - -- -- -------------- ------ - -- -- -- - ------ ----------------------- ------ - -- - -- -- -------------- ------ ----- -- - ----- - ----- ---- ----- - - ---- ------ ----------------------- ----- - ----- ---- ----- - -- -- -------------- ------ ----- -- - ----- - --- ----- ---- ----- - - ---- ------ ----------------------- ------ - -- -- ----- - ----- ---- ----- - -- -- -------------- ------ - -- -- -- - ------ ----------------------- ------ - -- - -- -- -- - -------------- - ---------
这里,我们通过 PrismaClient
类来实例化一个 Prisma 客户端,用于与数据库交互。在 resolvers
中,我们定义了 Query
和 Mutation
的各个字段,通过 Prisma 客户端实现相应的查询、更新、删除操作。
最后,我们需要在 index.js
文件中开启 Apollo Server,将 GraphQL schema 和 resolver 作为参数传入。
-- -------------------- ---- ------- ----- - ------------ - - ------------------------ ----- --------- - ---------------------- ----- - ------------ - - ------------- ----- ------ - --- -------------- --------- ------------------------------------ -------- ---------- -- ----------------------- --- -- -- - --------------- ------ ----- -- -------- --
现在,我们可以在命令行中执行:
node index.js
来启动 Apollo Server。
3. 将 GraphQL API 与 Prisma 数据库集成
目前,我们已经实现了 GraphQL API 和后端 Prisma 数据库操作的功能。但是,我们的 GraphQL API 并没有与 Prisma 数据库进行集成。因此,我们需要在 prisma/schema.prisma
中定义我们的 Query
和 Mutation
类型:
-- -------------------- ---- ------- ---- ----- - --------- ----------- ----------- ------ ------- --------- ----------- ----------- ------ ------- - ---- -------- - ------------------- --------------------- -------- ------------------- -------------------- ------ -------------------------- ------- -------------------- -------------------------- ------- ------------------- --------------------- -------- ------------------- -------------------- ------ -------------------------- ------- -------------------- -------------------------- ------- -
不难看出,这里的 Query
和 Mutation
类型与我们在 schema.graphql
文件中的定义一致,只是加了一些类型和参数。
接下来,我们需要在命令行中执行以下命令来同步 Prisma 数据模型和 GraphQL schema:
npx prisma generate npx graphql-codegen init
这样,Prisma 会自动生成与 GraphQL schema、TypeScript 类型和 CRUD resolver 相关的代码。
4. 使用 Prisma 客户端进行数据库操作
现在,我们已经完成了 GraphQL API 和 Prisma 数据库的集成,可以使用 Prisma 客户端来操作数据库了。以下是一些示例代码:
-- -------------------- ---- ------- ----- - ------------ - - ------------------------- ----- ------ - --- -------------- ----- ------------- - ----- -- ----- ---- ---- ----- -- -- - ----- ------- - ----- ----------------------- ----- - ----- ---- ---- ----- - -- ------ ------- - ----- ------------- - ----- -- --- ----- ---- ---- ----- -- -- - ----- ------- - ----- ----------------------- ------ - -- -- ----- - ----- ---- ---- ----- - -- ------ ------- - ----- ------------- - ----- -- -- -- -- - ----- ------- - ----- ----------------------- ------ - -- - -- ------ ------- - ----- ----------- - ----- -- -- -- -- - ----- ------- - ----- --------------------------- ------ - -- - -- ------ ------- - ----- -------- - ----- -- -- - ----- -------- - ----- ------------------------- ------ -------- - -------------- - - -------------- -------------- -------------- ------------ --------- -
以上代码定义了一些函数,用于实现学生信息的增、删、改、查等操作。使用 Prisma 客户端时,我们只需要调用相应的方法(如 prisma.student.create()
、prisma.student.update()
、prisma.student.delete()
、prisma.student.findUnique()
、prisma.student.findMany()
等)即可。
总结
本文介绍了如何使用 GraphQL 和 Prisma 实现后端 API。我们首先定义了 Prisma 数据模型,然后创建了 GraphQL schema 和 resolver,进而将 GraphQL API 与 Prisma 数据库集成。最后,我们展示了如何使用 Prisma 客户端来操作数据库。这些内容都可以作为借鉴和学习的参考资料。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/65484c287d4982a6eb2931f7