概述

  • 在 NestJS 的官方文档中,有两处对数据库进行了介绍
    • 第一处位于左侧“Techniques(技术)”部分下的“数据库”板块,中文文档里同样有这个位置。
      • Database
    • 第二处是下面的“Recipes (秘籍)”板块,这里有多个部分都与数据库相关
      • 例如 TypeORM、Mongoose、Prisma 等
      • 在英文文档中,也能看到相关内容,不过官方文档仍有很多部分未翻译
      • 如果小伙伴们有时间,也可以参与到这些开源项目的贡献中

集成 Prisma

下面,我们将依据官方文档,带领大家学习 Prisma 模块的集成方法

1 ) 创建 NestJS 项目

  • $ npm install -g @nestjs/cli
  • $ nest new hello-prisma

2 ) 设置 Prisma

  • $ cd hello-prisma
  • $ npm install prisma --save-dev
  • $ npx prisma 激活命令,可看到有一系列的 prisma 命令列表
    • prisma init
    • prisma generate
    • prisma studio
    • prisma migrate dev
    • prisma db pull
    • prisma db push
    • prisma validate
    • prisma format
    • prisma version
    • prisma debug
  • $ npx prisma init
    • 会创建 .env 的文件
    • 初始化(创建) prisma/schema.prisma
      generator client {provider = "prisma-client-js"
      }datasource db {provider = "postgresql"url      = env("DATABASE_URL")
      }
      
    • 可安装 vscode 相应的 prisma 插件显示高亮
    • 在 .env 文件中, 出现 DATABASE_URL 的配置
      DATABASE_URL="mysql://root:example@localhost:3306/testdb"
      
    • 参考:mysql#connection-url

3 ) 启动 mysql

编写 docker-compose.mysql.yaml

services:db:image: mysqlcommand: --default-authentication-plugin=mysql_native_passwordrestart: alwaysenvironment:MYSQL_ROOT_PASSWORD: exampleports:- 3306:3306adminer:image: adminerrestart: alwaysports:- 8080:8080
  • $ docker compose -f docker-compose.mysql.yaml up -d

4 ) 编辑 prisma/schema.prisma

generator client {provider = "prisma-client-js"
}datasource db {provider = "mysql"url      = env("DATABASE_URL")
}model User {id          Int       @id       @default(autoincrement())username    String    @uniquepassword    String@@map("user")
}

5 )创建一个初始化 的 migrate

$ npx prisma migrate dev --name init

prisma
├── dev.db
├── migrations
│   └── 20201207100915_init
│       └── migration.sql
└── schema.prisma
  • migrations 的作用是 做备份和迁移的过程会使用到的 sql 文件

6 ) 配置 prisma 相关服务

  • 安装 Prisma 客户端 $ npm install @prisma/client
  • 执行 $ npx prisma generate 针对上述 model 产生对应的 ts 类型

使用客户端

  • $ nest g mo database/prisma --no-spec
  • $ nest g s database/prisma --no-spec

prisma.module.ts

import { Module } from '@nestjs/common';
import { PrismaService } from './prisma.service';@Module({providers: [PrismaService],exports: [PrismaService],   // 要想跨模块使用,必须 exports 出来
})
export class PrismaModule {}

prisma.service.ts


import { Injectable, OnModuleInit } from '@nestjs/common';
import { PrismaClient } from '@prisma/client';@Injectable()
export class PrismaService extends PrismaClient implements OnModuleInit {async onModuleInit() {await this.$connect();}
}
  • 在 app.module.ts 中,默认已经 import 了 PrismaModule

  • 相当于把 prisma.module.ts 中所有的 providers 中的 service

  • 全部注册了,就可以使用 PrismaService 的实例 来直接注入到 controller 里面

    import { Controller, Get, Version } from '@nestjs/common';
    import { PrismaService } from './database/prisma/prisma.service';@Controller()
    export class AppController {constructor(private prismaService: PrismaService) {}@Get()// @Version('1')async getHello(): Promise<any> {const res = await this.prismaService.user.findMany({});return res;}
    }
    
  • 在 docker 服务中的 localhost:8080/#/login 登录数据库之后,创建 testdb

  • 这时候没有对应的表结构

  • 回到项目中,执行 $ npx prisma db push

  • 回到 adminer UI界面可以正常新建数据

  • 访问 localhost:3030/api/v1 即可看到新建数据

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/89965.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/89965.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/89965.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CppCon 2018 学习:What Do We Mean When We Say Nothing At All?

提供的内容深入探讨了C编程中的一些关键概念&#xff0c;特别是如何编写清晰、易维护的代码&#xff0c;并展示了一些C17的新特性。我将对这些内容做中文的解释和总结。 1. 良好的代码设计原则 什么是“良好的代码”&#xff1f; 能工作&#xff1a;代码实现了预期功能。能在…

C语言中的输入输出函数:构建程序交互的基石

在C语言的世界里&#xff0c;输入输出&#xff08;I/O&#xff09;操作是程序与用户或外部数据源进行交互的基本方式。无论是从键盘接收用户输入&#xff0c;还是将处理结果显示到屏幕上&#xff0c;亦或是读写文件&#xff0c;都离不开C语言提供的输入输出函数。本文将深入探讨…

高速信号眼图

横轴体系时域的抖动大小&#xff1b;纵轴体现电压的噪声。 噪声越大&#xff0c;眼高越小。 抖动越大&#xff0c;眼宽越窄。 眼图的模板是定义好的最大jitter和噪声的模板范围。就是信号的不可触碰区域。信号波形不能够触碰到模板或者进行模板中。也就是眼图中的线轨迹要在眼…

VisualSVN Server 禁止的特殊符号 导致的。具体分析如下:错误提示解读

是由于 文件夹名称中包含了 VisualSVN Server 禁止的特殊符号 导致的。具体分析如下&#xff1a; 错误提示解读 错误信息明确说明&#xff1a; Folder name cannot contain following symbols < > : " / | and start or end by period. 即 文件夹名称不能包含以下…

再见,WebSecurityConfigurerAdapter!你好,SecurityFilterChain

对于许多经验丰富的 Spring开发者来说&#xff0c;WebSecurityConfigurerAdapter 是一个再熟悉不过的名字。在很长一段时间里&#xff0c;它几乎是所有 Spring Security 配置的起点和核心。然而&#xff0c;随着 Spring Boot 3.x 和 Spring Security 6.x 的普及&#xff0c;这个…

web前端面试-- MVC、MVP、MVVM 架构模式对比

MVC、MVP、MVVM 架构模式对比 基本概念 这三种都是用于分离用户界面(UI)与业务逻辑的架构模式&#xff0c;旨在提高代码的可维护性、可测试性和可扩展性。 1. MVC (Model-View-Controller) 核心结构&#xff1a; Model&#xff1a;数据模型和业务逻辑View&#xff1a;用户界面展…

【C#】MVVM知识点汇总-2

在C#中实现MVVM&#xff08;Model-View-ViewModel&#xff09;架构时&#xff0c;可以总结以下几个关键知识点&#xff0c;并通过具体的代码示例来进行说明。 1. 模型 (Model) 模型包含应用程序中的数据和业务逻辑。通常与数据库交互。 public class User { public int Id {…

一文了解PMI、CSPM、软考、、IPMA、PeopleCert和华为项目管理认证

1 引言 常见的项目管理方面的认证有PMI、IPMA、PeopleCert、CSPM、软考和华为项目管理认证6个认证。本篇文章让你一文了解各认证的基本主要内容。 2 核心定位 目前全球范围内最具影响力的六大认证体系各有特色&#xff0c;源于不同的管理哲学和实践背景。六大认证体系的核心…

bean注入的过程中,Property of ‘java.util.ArrayList‘ type cannot be injected by ‘List‘

一、问题 在spring实践bean注入ArrayList属性的时候报错&#xff1a;Property of ‘java.util.ArrayList’ type cannot be injected by ‘List’二、原因分析 在尝试将 Spring 配置中的 注入到一个 ArrayList 类型的属性时出现了类型不匹配问题。核心问题在于&#xff1a;Spr…

自注意力机制原理: 向量矩阵案例进行说明

自注意力机制原理: 向量矩阵案例进行说明 目录 自注意力机制原理: 向量矩阵案例进行说明一个单词和所有单词进行乘法运算,提取特征一、场景设定:翻译句子“我喜欢深度学习”二、向量矩阵构建:以“我”为例计算自注意力三、矩阵视角:批量计算整个序列的自注意力四、向量矩…

D3 面试题100道之(61-80)

这里是D3的面试题,我们从第 61~80题 开始逐条解答。一共100道,陆续发布中。 🟨 面试题(第 61~80 题) 61. D3 中如何绘制饼图? 使用 d3.pie() 生成角度数据,再结合 d3.arc() 创建路径。 示例: const data = [10, 20, 30

flutter更改第三方库pub get的缓存目录;更改.gradle文件夹存放目录

1.在目标目录中新建文件夹flutter_pub_cache 2.在“用户变量“或“系统变量”中点击“新建” 变量名: PUB_CACHE 变量值: D:\flutter_pub_cache 3.打开新的终端运行或者从Android studio 控制台运行&#xff1a;flutter pub cache repair或者flutter pub clean pub读取新的变…

《Redis》哨兵模式

文章目录 为什么要有哨兵模式呢&#xff1f;哨兵自动恢复故障主节点使用docker搭建分布式系统查看哨兵节点工作哨兵选举新的主节点的流程 总结 为什么要有哨兵模式呢&#xff1f; 主从复制的问题 Redis 的主从复制模式可以将主节点的数据改变同步给从节点&#xff0c;这样从节…

零基础保姆级本地化部署文心大模型4.5开源系列

近两年随着大模型的迅猛崛起&#xff0c;吸引了各行各业的广泛关注&#xff0c;更对我们的工作方式与生活产生着显著积极影响。在这样一个技术范式转换的关键节点&#xff0c;百度文心大模型开源事件无疑具有里程碑意义——它不仅为中国自主研发的AI技术底座打开了通向世界的大…

【笔记】PyCharm 2025.2 EAP 创建 Poetry 和 Hatch 环境的踩坑实录与反馈

https://youtrack.jetbrains.com/issue/PY-82407/Incorrect-Python-Version-and-Virtual-Environment-Path-When-Creating-Poetry-and-Hatch-Environments-via-GUI-in-PyCharm-2025.2-EAP 在 Python 开发的道路上&#xff0c;PyCharm 一直是我们信赖的开发利器。然而&#xff0…

ASP.NET Web Pages 安装使用教程

一、ASP.NET Web Pages 简介 ASP.NET Web Pages 是微软推出的一种轻量级 Web 开发框架&#xff0c;适合快速开发动态网站。它使用 Razor 语法&#xff0c;可以将 HTML 与 C# 或 VB.NET 无缝融合&#xff0c;特别适合初学者和小型项目。 二、Web Pages 与 MVC 的区别 特性Web …

基于 ethers.js 的区块链事件处理与钱包管理

币圈工具箱 bqbot.cn 月访问量达90whttps://bqbot.cn/jms.html &#xff08;在线版地址&#xff09; Event事件 检索事件 const { ethers } require("hardhat"); async function SearchEvent() {try {const provider new ethers.JsonRpcProvider("http://1…

SpringBoot系列—入门

目录 1 第一个SpringBoot程序 1.1 创建SpringBoot项目 1.2 选择SpringBoot版本和必要依赖 1.3 项目目录结构 1.4 编写Hello World代码 1.5 运行程序 1.6 不需要IDEA也能创建SpringBoot程序 1.7 部署程序 1.8 pom.xml依赖问题 1.9 无Maven选项问题 1.10 SpringBoot版…

你的Prompt还有很大提升

与AI协作&#xff0c;Prompt&#xff08;提示词&#xff09;是沟通的桥梁。一个优秀的Prompt能让AI的输出事半功倍&#xff0c;而一个模糊的Prompt则可能导致南辕北辙的结果。如果你觉得AI的回答不够精准、缺乏深度&#xff0c;或者总带着一股“AI味”&#xff0c;那很可能是你…

3、Configuring Topics

如果您在应用程序上下文中定义了KafkaAdmin bean&#xff0c;它可以自动向代理添加主题。为此&#xff0c;您可以将每个主题的NewTopicBean添加到应用程序上下文中。2.3版本引入了一个新的类TopicBuilder&#xff0c;使创建此类bean更加方便。以下示例显示了如何执行此操作&…