首页 > 其他分享 >[VueJsDev] 其他知识 - NestJS 学习内容

[VueJsDev] 其他知识 - NestJS 学习内容

时间:2023-01-09 16:23:04浏览次数:69  
标签:prisma dto 知识 Step NestJS import article VueJsDev nestjs

[VueJsDev] 目录列表
https://www.cnblogs.com/pengchenggang/p/17037320.html

NestJS 学习内容

NestJS 学习总结

Step. 1: 全局安装包

pnpm add -g @nestjs/cli nodemon ts-node
nest new nestjs-api

Step. 2: 安装相关依赖

pnpm add prisma-binding @prisma/client mockjs @nestjs/config class-validator class-transformer argon2 @nestjs/passport passport passport-local @nestjs/jwt passport-jwt lodash multer dayjs express redis @nestjs/throttler

pnpm add -D prisma typescript @types/node @types/mockjs @nestjs/mapped-types @types/passport-local @types/passport-jwt @types/express @types/lodash @types/multer @types/node

Step. 3: prettierrc 配置文件

{
  "arrowParens": "always",
  "bracketSameLine": true,
  "bracketSpacing": true,
  "embeddedLanguageFormatting": "auto",
  "htmlWhitespaceSensitivity": "css",
  "insertPragma": false,
  "jsxSingleQuote": false,
  "printWidth": 120,
  "proseWrap": "never",
  "quoteProps": "as-needed",
  "requirePragma": false,
  "semi": false,
  "singleQuote": true,
  "tabWidth": 2,
  "trailingComma": "all",
  "useTabs": false,
  "vueIndentScriptAndStyle": false,
  "singleAttributePerLine": false
}

Step. 4: package.json 修改

-"start:dev": "nest start --watch",
+"dev": "nest start --watch",
  • 这样就能用快捷命令 d
  • http://localhost:3000

Step. 5: nest-cli.json 修改

{
  "$schema": "https://json.schemastore.org/nest-cli",
  "collection": "@nestjs/schematics",
  "sourceRoot": "src",
  "generateOptions": {
    "spec": false
  }
}
  • 使用命令 nest g res article
  • 或者用简写 n g res article (需配置快捷命令)
  • http://localhost:3000/article
  • 一个新接口就写好了 rest 方式

Step. 6: 数据库连接

npx prisma init
  • 会创建.env文件与prisma文件夹
  • .env 修改数据库连接
DATABASE_URL="mysql://root:admin888@127.0.0.1:3306/nest"

Step. 7: 定义数据库结构

  • npx prisma db pull 这条命令可以按照数据库生成schema.prisma文件
  • 下面我们按照写配置文件 生成数据的方式进行
  • prisman/schema.prisma
// This is your Prisma schema file,
// learn more about it in the docs: https://pris.ly/d/prisma-schema

generator client {
  provider = "prisma-client-js"
}

datasource db {
  provider = "mysql" // 这里改成mysql了
  url      = env("DATABASE_URL")
}

model article {
  id         Int      @id @default(autoincrement()) @db.UnsignedInt()
  title      String
  content    String   @db.Text()
}

  • prisma 插件记得装一下,就有颜色提示了

Step. 8: 生成迁移

npx prisma migrate dev
  • 根据定义生成迁移文件
  • 执行新的迁移文件修改数据表
  • 生成 Prisma Client

Step. 9: 重置数据库

npx prisma migrate reset
  • 删除数据库
  • 创建同名数据库
  • 执行所有迁移文件
  • 运行 seed 数据填充

Step. 10: 数据填充

首先在package.json中定义命令,后面可以调用 npx prisma db seed 命令实现填充

{
  "name": "nest",
  ...
  "prisma": {
    "seed": "ts-node prisma/seed.ts"
  },
  "scripts": {
  ...
  }
}
  • 新建 prisma/seed.ts
import { PrismaClient } from '@prisma/client'
import { Random } from 'mockjs'
const prisma = new PrismaClient()
async function run() {
  for (let i = 1; i <= 5; i++) {
    await prisma.article.create({
      data: {
        title: Random.ctitle(3, 6),
        content:Random.cparagraph(30, 50),
      },
    })
  }
}

run()
  • 执行 npx prisma db seed 填充数据

Step. 11: eslint 一个内联报错

Delete eslintprettier/prettier

  • 原因就是 win/apple/linux 系统的回车 有的是 \r 有的是 \n 有的是 \n\r 导致的
  • 解决方案
// .eslintrc.js
rules: {
  "endOfLine":"auto",
},

Step. 12: 添加prisma数据库读取工具包

全局的一个数据库读取工具包

n g mo prisma
n g s prisma
  • 代码
// src/prisma/prisma.module.ts
import { Global, Module } from '@nestjs/common';
import { PrismaService } from './prisma.service';

@Global()
@Module({
  providers: [PrismaService],
  exports: [PrismaService],
})
export class PrismaModule {}
  • 代码
// src/prisma/prisma.service.ts
import { PrismaClient } from '@prisma/client';
import { Injectable } from '@nestjs/common';

@Injectable()
export class PrismaService extends PrismaClient {
  constructor() {
    super({
      log: ['query'],
    });
  }
}

Step. 12: 添加 DTO 数据格式

ts 最大的特点就是要有type,所以对于article来说,就要有它对应的DTO

  • 数据传输对象(DTO)(Data Transfer Object),这个就是入参的类型
  • model 就是数据模型,对应数据库字段 大概这意思
// src\article\dto\create-article.dto.ts
export class CreateArticleDto {
  title: string
  content: string
}
  • 验证一般都放在DTO这里进行验证

Step. 13: 添加控制器-路由设置

先在控制器添加上路由先能访问

import { Body, Controller, Delete, Get, Param, Patch, Post } from '@nestjs/common'
import { ArticleService } from './article.service'
import { CreateArticleDto } from './dto/create-article.dto'
import { UpdateArticleDto } from './dto/update-article.dto'

@Controller('article')
export class ArticleController {
  constructor(private readonly articleService: ArticleService) {}

  @Post()
  create(@Body() createArticleDto: CreateArticleDto) {
    return this.articleService.create(createArticleDto)
  }

  // @Post('findAll')
  @Get('findAll')
  findAll() {
    return this.articleService.findAll()
  }

  @Post('findOne')
  findOne(@Body() dto: UpdateArticleDto) {
    console.info('findOne dto', dto)
    return this.articleService.findOne(dto)
  }
  
}

Step. 14: 添加控制器的服务Servce

控制器调用服务,服务里面写相关数据的内容

import { Injectable } from '@nestjs/common'
import { PrismaService } from 'src/prisma/prisma.service'
import { CreateArticleDto } from './dto/create-article.dto'
import { UpdateArticleDto } from './dto/update-article.dto'

@Injectable()
export class ArticleService {
  constructor(private prisma: PrismaService) {}
  create(createArticleDto: CreateArticleDto) {
    return 'This action adds a new article'
  }

  // findAll() {
  //   return `This action returns all article`
  // }
  async findAll() {
    const articles = await this.prisma.article.findMany()
    return {
      data: articles,
    }
  }

  async findOne(dto: UpdateArticleDto) {
    // return `This action returns a #${dto.id} article`
    const article = await this.prisma.article.findMany({
      where: {
        id: +dto.id,
      }
    })
    return {
      data: article
    }
  }
}

...

标签:prisma,dto,知识,Step,NestJS,import,article,VueJsDev,nestjs
From: https://www.cnblogs.com/pengchenggang/p/17037374.html

相关文章

  • [VueJsDev] 目录列表
    [VueJsDev]目录列表云服务器域名就一年,gitee上有不给发布,没办法https://www.vuejsdev.com/还是迁移到博客园吧。目录列表快速入门开发前小知识vue项目根目录配置......
  • [VueJsDev] 日志 - nginxConfig 配置文件备份
    [VueJsDev]目录列表https://www.cnblogs.com/pengchenggang/p/17037320.htmlnginxConfig配置文件备份:::details目录目录nginxConfig配置文件备份Step.1:服务器......
  • [VueJsDev] 日志 - BBTime-LOG
    [VueJsDev]目录列表https://www.cnblogs.com/pengchenggang/p/17037320.htmlBBTime-LOG:::details目录目录BBTime-LOGLog.1:AutoNumber成功发布到vscode插件市场......
  • 算法题基础知识汇总
     子串长度字符串python字符串的while()循环遍历​​http://www.cocoachina.com/articles/895083​​c-如何在std::vector中存储固定长度的字符串​​http://www.myexcep......
  • NLP基础知识学习掌握
    NLP入门总览教材推荐:实用文章NLP领域的重要模型100行代码完成的NLP任务好的课程NLP领域的几个研究方向与公共数据集NLP的基本方法和流程NLP基础知识1......
  • Linux基础知识
    LinuxLinux系统目录结构  在Linux或者Unix系统中,所有文件和目录都被组织成以一个根节点开始的树状结构,文件系统的最顶层是由根目录开始\,根目录下既可以是文件。如果......
  • python 每天一个知识点 第四天
    字符串:一,字符串的定义:使用单引号’你可以用单引号指示字符串,就如同’这是一句话’这样str='这是一句话'print(str)使用双引号"在双引号中的字符串与单引......
  • 前端知识点
    1.字体不加粗font_weight:normal;2.设置垂直居中line-height:50px;#行高和盒子的宽度设置为一样3.首行缩进text-indent:20px;......
  • 38预处理器指令 知识点
    //什么是编译器//编译器是一种翻译程序//它用于将源语言程序翻译为目标语言程序//源语言程序:某种程序设计语言写成的,比如C#、C、C++、JAVA等语言写的程序//目标语言程......
  • 36 多线程 知识点
    //了解进程//进程(Process)是计算机中的程序关于某数据集合上的一次运行活动//是系统进行资源分配和调度的基本单位,是操作系统结构的基础//说人话:打开一个应用程序就是在......