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

Next.js第二十四章(Prisma)

ORM框架(Object-Relational Mapping)

在传统开发模式中,我们需要把数据存储到数据库,所以需要通过SQL语句来进行操作,例如查询新增修改删除等操作,但是SQL语句太多了,还比较繁琐,所以就有了ORM框架。

ORM框架简单来说就是让我们通过熟悉的语法来操作数据库,我们可以直接使用面向对象的方式来操作数据库,ORM会把我们的操作映射成SQL语句,然后执行。

面向对象查询:

constuser=awaitthis.prisma.user.findUnique({where:{id:1},select:{id:true,name:true,email:true}})console.log(user)

SQL查询:

SELECTid,name,emailFROMusersWHEREid=1

Prisma

ORM框架比较多,这里我选择使用Prisma,因为PrismaTypeScript优先的ORM框架,并且支持多种数据库,包括MySQLPostgreSQLSQLiteMongoDB等。它以其出色的性能、类型安全性以及与 GraphQL 和 REST API 的集成而闻名

注:我们当前使用的prisma版本是7.3.0为目前最新版(2026-01-29),他每个大版本是有很大差异的,所以建议大家跟我安装一样的版本。

Postgresql

数据库的种类也是非常多的,这里我选择使用PostgreSQL,完全开源免费,我称为世界第一数据库(个人言论),因为他有非常强大的功能,例如支持高级数据类型,JSON数组枚举布尔值地理空间GIS,事务与并发能力更强,并且还支持自定义扩展其功能。

PostgresSQL安装教程

  1. 简单粗暴,访问官网https://www.postgresql.org/download/,选择适合你操作系统的版本,然后下载安装即可。



  1. 使用docker安装
dockerpull postgres:18dockerrun -d --name postgresServer -p6666:5432 -ePOSTGRES_PASSWORD=123456postgres:18

账号默认为postgres,密码为123456,端口号为6666

安装数据库可视化工具:打开vsCode/Cursor/WebStorm等代码编辑器,安装Database Client插件,然后连接数据库即可。


开始使用Prisma

安装prisma:

npmi prisma -D

安装prisma客户端:

npminstall@prisma/client @prisma/adapter-pg pg dotenv

注: prisma7版本需要独立安装适配器

例如postgresql需要安装@prisma/adapter-pgmysql需要安装@prisma/adapter-mariadb

其他数据库请参考https://www.prisma.io/docs/getting-started/prisma-orm/quickstart/prisma-postgres

在Next.js项目根目录执行以下命令,初始化prisma:

npx prisma init

执行完成之后他会自动生成prisma文件夹,并且生成schema.prisma文件,以及创建一个env文件和prisma.config.ts文件。

打开prisma/schema.prisma文件,添加以下内容:

generator client{provider="prisma-client"//使用什么客户端output="../src/generated/prisma"//生成客户端代码的目录}datasource db{provider="postgresql"//连接什么数据库}model User{id String @id @default(cuid())//主键name String//用户名email String @unique//邮箱password String//密码createdAt DateTime @default(now())//创建时间updatedAt DateTime @updatedAt//更新时间posts Post[]//关联文章}model Post{id String @id @default(cuid())//主键title String//标题content String//内容createdAt DateTime @default(now())//创建时间updatedAt DateTime @updatedAt//更新时间authorId String//作者IDauthor User @relation(fields:[authorId],references:[id],onDelete:Cascade,onUpdate:Cascade)//一对多关联}
  • @id:主键对应sql语句的PRIMARY KEY
  • @default(cuid()):默认生成一个唯一ID 类似于sql语句的AUTO_INCREMENT
  • @unique:唯一约束对应sql语句的UNIQUE
  • @relation:一对多关联对应sql语句的FOREIGN KEY
  • @relation(fields: [authorId], references: [id],onDelete: Cascade,onUpdate: Cascade):一对多关联对应sql语句的FOREIGN KEY
  • @default(now()):默认生成当前时间 类似于sql语句的CURRENT_TIMESTAMP
  • @updatedAt:更新时间 类似于sql语句的UPDATE CURRENT_TIMESTAMP
  • onDelete: Cascade:级联删除(表示删除主表的时候,从表也删除,非常的方便啊)
  • onUpdate: Cascade:级联更新(表示更新主表的时候,从表也更新,非常的方便啊)

打开.env文件,修改数据库连接信息:

连接规则:DATABASE_URL=“postgresql://username:password@localhost:5432/mydb?schema=public”

  • postgresql:数据库类型
  • username:用户名
  • password:密码
  • localhost:主机名
  • 5432:端口号
  • mydb:数据库名
  • schema=public:模式
DATABASE_URL="postgresql://postgres:123456@localhost:6666/test_db"

执行数据库迁移命令:

npx prisma migrate dev --name init

执行完成之后他会在prisma/migrations文件夹中生成一个migration文件,并且生成一个sql文件,然后自动执行sql文件,创建表结构。

接着执行生成客户端代码命令:

npx prisma generate#生成路径是 schema.prisma 文件中client output的目录

编写增删改查

src/lib/prisma.ts

import{PrismaClient}from'../generated/prisma/client'//引入生成客户端代码import{PrismaPg}from'@prisma/adapter-pg'//引入适配器constpool=newPrismaPg({connectionString:process.env.DATABASE_URL})//创建连接池constprisma=newPrismaClient({adapter:pool})//创建客户端exportdefaultprisma//导出客户端

src/app/api/route.ts

importprismafrom"@/lib/prisma";//@lib是我在tsconfig.json中配置的别名,表示src目录下的lib文件夹import{NextRequest,NextResponse}from"next/server";//引入NextRequest, NextResponseexportasyncfunctionGET(request:NextRequest){constusers=awaitprisma.user.findMany()//查询所有用户returnNextResponse.json(users)//返回用户列表}exportasyncfunctionPOST(request:NextRequest){const{name,email,password}=awaitrequest.json()//获取请求体constuser=awaitprisma.user.create({data:{name,email,password}//创建用户})returnNextResponse.json(user)//返回创建的用户}exportasyncfunctionPATCH(request:NextRequest){const{id,name,email,password}=awaitrequest.json()//获取请求体constuser=awaitprisma.user.update({where:{id},data:{name,email,password}//更新用户})returnNextResponse.json(user)//返回更新后的用户}exportasyncfunctionDELETE(request:NextRequest){const{id}=awaitrequest.json()//获取请求体constuser=awaitprisma.user.delete({where:{id}//删除用户})returnNextResponse.json(user)//返回删除后的用户}

index.http

执行http文件需要在插件市场安装REST Client,然后打开http文件,点击Send Request按钮即可。

### 创建用户POST http://localhost:8888/api Content-Type: application/json{"name":"test","email":"1test@test.com","password":"123456"}### 查询所有用户GET http://localhost:8888/api### 更新用户PATCH http://localhost:8888/api Content-Type: application/json{"id":"cmkyoxflr00004ck82ywc6joi","name":"xiaoman","email":"xiaomansdasdas","password":"dasdasda"}### 删除用户DELETE http://localhost:8888/api Content-Type: application/json{"id":"cmkyoxflr00004ck82ywc6joi"}
http://www.jsqmd.com/news/318511/

相关文章:

  • 一道很适合std::multiset的题目
  • 丰宝斋上门回收各类旧书老书,破解藏家变现痛点,老字号全程护航
  • 【高级版】彩虹发卡在线自动平台系统
  • 大模型微调实战:Hugging Face Transformers全流程解析与代码实现 | 程序员必学收藏
  • 智能体来了:2026,AI 元年开启的新赛道
  • 鲸发卡v11.71系统源码+企业自动发卡网源码
  • wp子比主题发卡插件源码zibll主题发卡插件
  • 云计算第四次作业
  • 【源码教学搭建】支付宝小程序联盟源码支持搭建出行比价
  • 省选集训 16 - 杂题
  • 基于springboot的星之语明星周边产品销售网的设计与实现项目源码 java毕设 免费分享
  • 基于kmeans的集群划分,ieee33节点,包括集群划分指标等结果信息,部分如图所示
  • 大数据领域如何利用HDFS实现高效的数据共享
  • 2025-2026 学年度上期期末考试游记
  • AI Agent 框架探秘:拆解 OpenHands(4)--- 服务
  • 小程序公司按综合实力来排名:2026年谁是你数字化转型的最佳伙伴?
  • 【硬核】HR大模型开发实战:构建智能Agent,解放打工人从招聘开始
  • 丰宝斋上门回收民国书老医书,针对性回收,小众珍品不被埋没
  • 使用三个线程按顺序打印ABC,循环打印10次
  • 【C语言】学习
  • 【AI已死?】中国大模型下载破百亿,技术路线从“聊天“到“做事“,程序员:我的代码还有价值吗?
  • 北京上门回收古书老书,丰宝斋三重鉴定,精准估价不被压价
  • 气动人工肌肉的控制-EXP-自动控制-气动肌肉
  • 需求其实并非在谈需求
  • 如果我们必须构建软件,那么它必须为拥有它的人提供最理想的价值。
  • 2026最新18k金镶嵌/18k金微硬金加工工厂推荐广州市金优选珠宝有限公司:工艺与设计双优,实力领跑
  • 在杭州的小程序公司深度对比:哪家才是你的技术专家?
  • 在北京做小程序开发的公司哪家好?打造数字化转型利器
  • 2026小程序公司十大排名:选对服务商,抢占数字市场先机
  • 2026小程序公司前十大排名:哪家才是更深入民心?