Prisma初体验【逆向生成数据模型】

Prisma逆向生成数据模型

初次体验Prisma工程搭建,在ORM领域表现不错。Prisma是一个面向Node.js和TypeScript的开源ORM。它用于替代编写普通的SQL,或使用另一种数据库访问工具,如SQL查询生成器(如knex.js)或ORMs(如TypeORM和Sequelize)。Prisma目前支持PostgreSQL、MySQL、SQLServer和SQLite。虽然Prisma可以与普通JavaScript一起使用,但它包含TypeScript,并提供了一种类型安全级别,超出TypeScript生态系统中其他Orm的保证范围。如下工程在window 10环境下的实施。

1.创建工程目录

D:\project\example\typeorm> mkdir hello-prisma
D:\project\example\typeorm> cd hello-prisma

2.项目初始化

D:\project\example\typeorm>npm init -y 
D:\project\example\typeorm>npm install prisma typescript ts-node @types/node --save-dev

3.创建tsconfig.json

在工程更目录下创建tsconfig.json,并添加如下配置信息:

{
  "compilerOptions": {
    "sourceMap": true,
    "outDir": "dist",
    "strict": true,
    "lib": ["esnext"],
    "esModuleInterop": true
  }
}

注:可以使用tsc --init创建,windows系统需要识别tsc命令。

4.创建Prisma schema文件

在工程目录中使用如下命令创建Prisma schema文件(系统默认文件名为schema.prisma):

D:\project\example\typeorm> npx prisma init

5.工程目录

在这里插入图片描述
注意:index.ts文件为后期创建的文件。

6.配置数据信息

在工程目录中的.env文件中设置DATABASE_URL(本工程使用的mysql数据库):

DATABASE_URL="mysql://[用户名]:[密码]@localhost:3306/world?schema=public"

在prisma文件夹下的schema.prisma文件中修改数据库类型:

datasource db {
  provider = "mysql" //初始默认值为“postgresql”
  url      = env("DATABASE_URL")
}

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

7.逆向生成数据模型

使用如下命令生成数据模型【数据库中存在表数据】:

D:\project\example\typeorm> npx prisma introspect

在文件中系统会自动增加模型数据信息:

model post {
  id        Int      @id @default(autoincrement())
  createdAt DateTime @default(now())
  updatedAt DateTime
  title     String   @db.VarChar(255)
  content   String?
  published Boolean  @default(false)
  authorId  Int
  user      user     @relation(fields: [authorId], references: [id])

  @@index([authorId], name: "authorId")
}
//如下是新增model部分
model profile {
  id     Int     @id @default(autoincrement())
  bio    String?
  userId Int     @unique
  user   user    @relation(fields: [userId], references: [id])
}

model user {
  id      Int      @id @default(autoincrement())
  email   String   @unique
  name    String?
  post    post[]
  profile profile?
}

8.变更数据表中的信息

在工程目录文件中添加index.ts文件,其内容如下:

import { PrismaClient } from '@prisma/client'
const prisma = new PrismaClient()
async function main() {
// ... you will write your Prisma Client queries here
//查询数据库中user的记录数据
const allUsers = await prisma.user.findMany()
console.log(allUsers)
  
//对user表进行添加数据
 await prisma.user.create({
   data: {
     name: 'Alice',
     email: 'alice@prisma.io',
     posts: {
       create: { title: 'Hello World' },
     },
     profile: {
       create: { bio: 'I like turtles' },
     },
   },
 })
//查找数据
 const allUsers1 = await prisma.user.findMany({
   include: {
     posts: true,
     profile: true,
   },
 })
 console.dir(allUsers1, { depth: null })
//更新post数据
 const post = await prisma.post.update({
   where: { id: 1 },
   data: { published: true },
 })
 console.log(post)
 
 const posts = await prisma.profile
  .findUnique({
    where: { id: 1 },
  })
  .user()
  .posts()
  console.log(posts)
}
main()
  .catch(e => {
    throw e
  })
  .finally(async () => {
    await prisma.$disconnect()
})

9.执行index.ts文件

使用如下命令执行index.ts脚本:

D:\project\example\typeorm> npx ts-node index.ts

总结,简单、明了、高效,让程序员更加关注业务。Typeorm同样是体验性很好的ORM,就是在逆向工程方面在npm v7版本下bug问题,大多是包不兼容问题。后期会继续研究与整合新组件或框架,搭建一个高效的研发平台架构。敬请关注,谢谢!

已标记关键词 清除标记
相关推荐
<p> <b><span style="background-color:#FFE500;">【超实用课程内容】</span></b> </p> <p> <br /> </p> <p> <br /> </p> <p> 本课程内容包含讲解<span>解读Nginx的基础知识,</span><span>解读Nginx的核心知识、带领学员进行</span>高并发环境下的Nginx性能优化实战,让学生能够快速将所学融合到企业应用中。 </p> <p> <br /> </p> <p style="font-family:Helvetica;color:#3A4151;font-size:14px;background-color:#FFFFFF;"> <b><br /> </b> </p> <p style="font-family:Helvetica;color:#3A4151;font-size:14px;background-color:#FFFFFF;"> <b><span style="background-color:#FFE500;">【课程如何观看?】</span></b> </p> <p style="font-family:Helvetica;color:#3A4151;font-size:14px;background-color:#FFFFFF;"> PC端:<a href="https://edu.csdn.net/course/detail/26277"><span id="__kindeditor_bookmark_start_21__"></span></a><a href="https://edu.csdn.net/course/detail/27216">https://edu.csdn.net/course/detail/27216</a> </p> <p style="font-family:Helvetica;color:#3A4151;font-size:14px;background-color:#FFFFFF;"> 移动端:CSDN 学院APP(注意不是CSDN APP哦) </p> <p style="font-family:Helvetica;color:#3A4151;font-size:14px;background-color:#FFFFFF;"> 本课程为录播课,课程永久有效观看时长,大家可以抓紧时间学习后一起讨论哦~ </p> <p style="font-family:"color:#3A4151;font-size:14px;background-color:#FFFFFF;"> <br /> </p> <p class="ql-long-24357476" style="font-family:"color:#3A4151;font-size:14px;background-color:#FFFFFF;"> <strong><span style="background-color:#FFE500;">【学员专享增值服务】</span></strong> </p> <p class="ql-long-24357476" style="font-family:"color:#3A4151;font-size:14px;background-color:#FFFFFF;"> <b>源码开放</b> </p> <p class="ql-long-24357476" style="font-family:"color:#3A4151;font-size:14px;background-color:#FFFFFF;"> 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 </p> <p class="ql-long-24357476" style="font-family:"color:#3A4151;font-size:14px;background-color:#FFFFFF;"> 下载方式:电脑登录<a href="https://edu.csdn.net/course/detail/26277"></a><a href="https://edu.csdn.net/course/detail/27216">https://edu.csdn.net/course/detail/27216</a>,播放页面右侧点击课件进行资料打包下载 </p> <p> <br /> </p> <p> <br /> </p> <p> <br /> </p>
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页