当前位置: 首页 > news >正文

互联网软件门户网站上海百度推广电话客服

互联网软件门户网站,上海百度推广电话客服,国内好用的搜索引擎,昆明贤邦网站建设技术栈 nextjsnestjsprisma所学知识 Nextjs组件渲染,状态,路由docker启动Mysql容器prisma操作Mysql(CRUD)允许跨域请求APITanStack Query异步状态管理fetch api服务器组件预请求数据nestjs 管道和异常处理检测id是否正整数Docker启动Mysql容器 compose.yml name: todoLis…

技术栈

  • nextjs
  • nestjs
  • prisma

所学知识

  1. Nextjs组件渲染,状态,路由
  2. docker启动Mysql容器
  3. prisma操作Mysql(CRUD)
  4. 允许跨域请求API
  5. TanStack Query异步状态管理
  6. fetch api
  7. 服务器组件预请求数据
  8. nestjs 管道和异常处理
  9. 检测id是否正整数

Docker启动Mysql容器

compose.yml

name: 'todoList'
version: '3.8'
services:mysql:restart: alwayscontainer_name: todolistimage: mysql:8volumes:- ./mysql/datadir:/var/lib/mysql- ./mysql/config/my.cnf:/etc/mysql/my.cnfenvironment:- "MYSQL_ROOT_PASSWORD=root"- "TZ=Asia/Shanghai"ports:- 3306:3306

切换到compose.yml所在目录,cmd

docker-compose up

![[Pasted image 20241124230249.png]]

初始化prisma

npm install prisma --save-dev
npx prisma init

生成配置文件

设置数据库连接(mysql)

// This is your Prisma schema file,
// learn more about it in the docs: https://pris.ly/d/prisma-schema// Looking for ways to speed up your queries, or scale easily with your serverless or edge functions?
// Try Prisma Accelerate: https://pris.ly/cli/accelerate-initgenerator client {provider = "prisma-client-js"
}datasource db {provider = "mysql"url      = env("DATABASE_URL")
}

设置数据库连接环境变量

DATABASE_URL="mysql://root:root@localhost:3306/todos?schema=public"
  • todos是数据库名

设置表

model Todo {id        Int      @id @default(autoincrement())title     Stringcompleted Boolean? @default(false)createdAt DateTime @default(now())
}
npx prisma migrate dev --name init

![[Pasted image 20241124221851.png]]

回到初始化状态(测试用)

会删除数据库数据但是prisma配置内容还在

npx prisma migrate reset

定义prisma client

npm install @prisma/client

Prisma Client 是一个类型安全的数据库客户端,它是从 Prisma 模型定义生成的。由于这种方法,Prisma Client 可以公开专门为您的模型量身定制的 CRUD 操作。

请注意,在安装过程中,Prisma 会自动为您调用 prisma generate 命令。将来,您需要在每次更改 Prisma 模型后运行此命令,以更新生成的 Prisma Client。

使用prisma client

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();}
}

onModuleInit 是可选的 — 如果你省略它,Prisma 将在第一次调用数据库时延迟连接。

注意

app.module要引入PrismaService

import { Module } from '@nestjs/common';
import { PrismaService } from 'src/prisma.service';
import { AppController } from './app.controller';
import { AppService } from './app.service';
import { TodoController } from './todo/todo.controller';
import { TodoService } from './todo/todo.service';@Module({imports: [],controllers: [AppController, TodoController],providers: [AppService, TodoService, PrismaService],
})
export class AppModule {}

不然报错

prisma调用数据库操作

接下来,您可以编写可用于从 Prisma 架构对 todo模型进行数据库调用的服务。

import { Body, Controller, Get, Post } from '@nestjs/common';
import { TodoService } from 'src/todo/todo.service';@Controller('todo')
export class TodoController {constructor(private readonly todoService: TodoService) {}@Post()async createTodo(@Body() createTodoDto: any) {return this.todoService.createTodo(createTodoDto);}
}
import { Injectable } from '@nestjs/common';
import { PrismaService } from 'src/prisma.service';@Injectable()
export class TodoService {constructor(private prisma: PrismaService) {}async createTodo(data: any) {const todo = await this.prisma.todo.create({data: {title: data.title,completed: false,},});return todo;}
}
  • private

这确保了封装,这意味着没有其他类或外部代码可以直接访问 todoService 属性,这是维护干净且可预测的代码的良好做法。

  • readonly

这是有益的,因为服务实例应在控制器的整个生命周期中保持不变。它可以防止意外重新分配 todoService 属性,这可能会导致 bug。

  @Delete(':id')async deleteTodoById(@Param('id') id: string) {return this.todoService.deleteTodoById(+id);}
async getTodoById(id: number
http://www.15wanjia.com/news/42423.html

相关文章:

  • 建设企业银行官方网站珠海seo排名收费
  • wordpress注册会员无法收到邮件聊城seo整站优化报价
  • 广东网站建设哪家好广东seo网站推广
  • 做公司网站的步骤专门开发小程序的公司
  • 湖南微信网站线上直播营销策划方案
  • 企航互联提供天津网站建设做网络推广费用
  • 安徽元鼎建设公司网站无货源网店怎么开
  • 2015做导航网站好电子商务说白了就是干什么的
  • 电子商务网站开发进什么科目百度小说排名
  • 旅游网站的设计方案怎么做seo关键词排名技巧
  • 可以做ps兼职的网站搜索引擎分哪三类
  • 海南行指海口网站开发在线种子资源库
  • wordpress获取摘要seo推广专员工作好做吗
  • 找人做网站服务器不是自己的怎么办热门关键词排名查询
  • 泰安网站开发seo外链发布技巧
  • 在线自助下单网站seo 重庆
  • 淘宝内部优惠券网站怎样做的青山seo排名公司
  • 灵感中心素材网站seo交流论坛seo顾问
  • 怎么请人做网站内江seo
  • 免费自助建站网站一览谷歌google官网入口
  • 如何做网站内页排名北京seo外包平台
  • wordpress 性能调优网络seo是什么意思
  • 如何做服装的微商城网站赚钱平台
  • 旅游网站开发功能中央新闻联播
  • 网站开发运营网络优化大师
  • wordpress dms应用商店优化
  • 建设网站的网站叫什么广告关键词查询
  • 社交网站开发客户临沂做网络优化的公司
  • 专业的设计网站有哪些内容百度推广北京总部电话
  • 备案时网站名称最好的推广平台排名