保姆级教程——号称下一代Node.js,Typescript的orm的prisma 如何在nest.js中使用

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 保姆级教程——号称下一代Node.js,Typescript的orm的prisma 如何在nest.js中使用

什么是orm

ORM(对象关系映射)是一种技术或工具,用于在关系型数据库和面向对象编程语言之间建立映射关系。它允许开发人员使用面向对象的方式来操作数据库,而无需直接编写复杂的 SQL 查询。

ORM 的主要目标是减少开发人员在数据库操作和对象操作之间的转换工作,提高开发效率并降低出错的可能性。它通过将数据库表映射为对象的类,将表中的行映射为对象的实例,以及将表中的列映射为对象的属性,使得开发人员可以使用常见的面向对象的概念(例如继承、关联等)来处理数据。

ORM 框架通常提供以下功能:

  1. 对象关系映射:将数据库表和行映射为对象和对象属性。
  2. 查询语言:提供一种高级的查询语言,使开发人员能够以面向对象的方式执行数据库查询,而不是直接编写 SQL 查询。
  3. 数据库操作:封装数据库的增删改查操作,提供简洁的接口来操作数据。
  4. 缓存管理:提供缓存机制以提高性能,并减少对数据库的访问。
  5. 数据关联和关系管理:支持定义和管理对象之间的关联关系,例如一对一、一对多、多对多等关系。
  6. 事务管理:提供事务支持,确保数据库操作的原子性和一致性。

一些常见的 ORM 框架包括:Hibernate(Java)、Entity Framework(.NET)、Django ORM(Python)、Sequelize(Node.js)等。这些框架提供了强大的功能和工具,简化了与数据库的交互,使开发人员能够更专注于业务逻辑而不是底层的数据库操作。

使用 ORM 可以提高开发效率、减少代码量,并且更易于维护和重构。然而,ORM 也有一些局限性,例如性能损耗、复杂查询的限制等。因此,在选择使用 ORM 还是直接编写 SQL 查询时,需要根据具体的项目需求和性能要求进行权衡和选择。

为什么选择prisma

Prisma 的主要目标是提高应用程序开发人员在使用数据库时的工作效率。以下是Prisma如何实现这一目标的几个例子:

  • 在对象中思考而不是映射关系数据
  • 查询而不是类以避免复杂的模型对象
  • 数据库和应用程序模型的单一事实来源
  • 防止常见陷阱和反模式的健康约束
  • 使正确的事情变得容易的抽象( “成功坑”)
  • 可在编译时验证的类型安全数据库查询
  • 减少样板 因此开发人员可以专注于其应用的重要部分
  • 在代码编辑器中自动完成, 无需查找文档

综合来说,Orm让开发者更关心对象的思考,减少对sql的依赖

Prisma 的主要目标是提高应用程序开发人员在使用数据库时的工作效率。再次考虑生产力和控制之间的权衡,这就是Prisma的适应方式:

image.png

在nest.js项目中构建prisma

项目所需依赖包如下:


pnpm add prisma-binding @prisma/client 
pnpm add -D prisma

vscode扩展记得要下载prisma插件,这样会有代码高亮以及提示

image.png

安装完成后,就可以开始我们的项目了

image.png

在命令行输入pnpm prisma 之后可以看到prisma的命令,本篇博客只介绍几种常用的的命令

首先用pnpm prisma init初始化我们的项目,完成后,可以看到出现了一个.env文件,它是配置数据连接的地方

image.png

我这里就以mysql为例,这是我的mysql连接的账户信息 我们在用prisma时,它可以自动帮我们创建好表的,最后的那一块定义自己想要的表名就行

image.png

image.png

接下来写第一张表

image.png

prisma对mysql的数据格式的封装

image.png

@default(autoincrement)是定义id让它自增长 在定义id时必须加上@id 不然会出错 , @db.xxx

后面都是mysql数据库的一些方法,比如你不想要String 想要255的,就可以


username String @db.VarChar(255)

在写完一张表的结构后 需要pnpm prisma migrate dev生成迁移文件

image.png

每次跑会让我们定义一个名字,自定义就行,也可以不给,直接回车即可

可以看到迁移文件生成的文件目录,这里类似于日志记录着每一次我们数据库的改动

image.png

接着打开数据库可视化工具看看

image.png

接下来我们要来对其进行一些crud的操作吧

首先创建一个prisma服务模块,我们引入查询构造器,让服务继承这个类,在prisma中很重要的就是这个查询构造器,它可以帮助我们实现一系列的功能

image.png

接着在controller中使用服务 创建一个基本的crud模板,请求都是异步的,所以需要用上async await

prisma.controller.ts

复制代码

import { Controller, Get, Post, Body, Patch, Param, Delete, UsePipes, ParseIntPipe } from '@nestjs/common';
import { PrismaService } from './prisma.service';
@Controller('prisma')
export class PrismaController {
    constructor(private readonly prisma: PrismaService) { }
    @Get()
    async getUser() {
        return await this.prisma.user.findMany()
    }
    @Post()
    async createUser(@Body() dto: { username: string, age: number }) {
        return await this.prisma.user.create({
            data: {
                username: dto.username,
                age: +dto.age
            }
        })
    }
    @Patch(':id')
    async updateUser(@Param('id') id: number, @Body() dto: { username: string, age: number }) {
        return await this.prisma.user.update({
            where: {
                id: +id
            },
            data: {
                username: dto.username,
                age: +dto.age
            }
        })
    }
    @Delete(':id')
    @UsePipes(ParseIntPipe)
    async deleteUser(@Param('id') id: number) {
        return await this.prisma.user.delete({
            where: {
                id: id
            }
        })
    }
}

prisma非常的语义化 查询全部就是findMany()里面也可以跟where加限定条件 分页等

创建create 删除delete 更新update 大家可以自己尝试一下

写在最后

关于prisma还要挺多知识的,orm我也用过typeOrm 对比一下 prisma确实更为方便,无论哪一个都是为了提高我们开发效率,简化了操作,但是对于原生sql来说我们也要好好学习,因为很多api都是sql里面的,这样开发起来我们知道了sql的操作,就知道prima的操作了,不用多记这些api,希望这篇文章能帮助到大家吧!

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
Web App开发 JavaScript 前端开发
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念,包括事件驱动、单线程模型和模块系统;探讨其安装配置、核心模块使用、实战应用如搭建 Web 服务器、文件操作及实时通信;分析项目结构与开发流程,讨论其优势与挑战,并通过案例展示 Node.js 在实际项目中的应用,旨在帮助开发者更好地掌握这一强大工具。
618 1
|
9月前
|
JavaScript 前端开发 安全
【逆向】Python 调用 JS 代码实战:使用 pyexecjs 与 Node.js 无缝衔接
本文介绍了如何使用 Python 的轻量级库 `pyexecjs` 调用 JavaScript 代码,并结合 Node.js 实现完整的执行流程。内容涵盖环境搭建、基本使用、常见问题解决方案及爬虫逆向分析中的实战技巧,帮助开发者在 Python 中高效处理 JS 逻辑。
|
机器学习/深度学习 JavaScript 前端开发
JS进阶教程:递归函数原理与篇例解析
通过对这些代码示例的学习,我们已经了解了递归的原理以及递归在JS中的应用方法。递归虽然有着理论升华,但弄清它的核心思想并不难。举个随手可见的例子,火影鸣人做的影分身,你看到的都是同一个鸣人,但他们的行为却能在全局产生影响,这不就是递归吗?雾里看花,透过其间你或许已经深入了递归的魅力之中。
438 19
|
资源调度 JavaScript 前端开发
前端开发必备!Node.js 18.x LTS保姆级安装教程(附国内镜像源配置)
本文详细介绍了Node.js的安装与配置流程,涵盖环境准备、版本选择(推荐LTS版v18.x)、安装步骤(路径设置、组件选择)、环境验证(命令测试、镜像加速)及常见问题解决方法。同时推荐开发工具链,如VS Code、Yarn等,并提供常用全局包安装指南,帮助开发者快速搭建高效稳定的JavaScript开发环境。内容基于官方正版软件,确保合规性与安全性。
15131 23
|
Web App开发 JavaScript 前端开发
2024年5月node.js安装(winmac系统)保姆级教程
本篇博客为2024年5月版Node.js安装教程,适用于Windows和Mac系统。作者是一名熟悉JavaScript与Vue的大一学生,分享了Node.js的基本介绍、下载链接及简单安装步骤。安装完成后,通过终端命令`node -v`验证版本即可确认安装成功。欢迎关注作者,获取更多技术文章。
1075 2
2024年5月node.js安装(winmac系统)保姆级教程
|
存储 JavaScript NoSQL
Node.js新作《循序渐进Node.js企业级开发实践》简介
《循序渐进Node.js企业级开发实践》由清华大学出版社出版,基于Node.js 22.3.0编写,包含26个实战案例和43个上机练习,旨在帮助读者从基础到进阶全面掌握Node.js技术,适用于初学者、进阶开发者及全栈工程师。
370 9
|
JSON JavaScript 前端开发
使用JavaScript和Node.js构建简单的RESTful API
使用JavaScript和Node.js构建简单的RESTful API
|
开发框架 JavaScript 前端开发
Node.js日记:客户端和服务端介绍、Node.js介绍
Node.js日记:客户端和服务端介绍、Node.js介绍
|
JavaScript 前端开发 开发工具
Node.js——初识Node.js
Node.js——初识Node.js
280 4