nest中的ORM

在 Nest.js 中执行 SQL 查询通常涉及使用 TypeORM 或 Sequelize 这样的 ORM(对象-关系映射)库。这些库使得在 Nest.js 应用程序中连接和操作 SQL 数据库变得更加简单和直观。

以下是一个使用 TypeORM 在 Nest.js 中执行 SQL 查询的示例代码:

首先,确保你已经在项目中安装了 TypeORM:

在user模块中的entites中;user.entity.ts中有如下代码:

复制代码
import { Column, Entity, PrimaryGeneratedColumn } from "typeorm";
@Entity()
export class User {
  @PrimaryGeneratedColumn()
  id: number
  @Column()
  username: string
  @Column()
  password: string
}

在user模块中的service中;user.service.ts中有如下代码:

复制代码
import { Injectable } from '@nestjs/common';
import { UserDto } from './dto/create-user.dto';
import { InjectRepository } from '@nestjs/typeorm';
import { User } from './entities/user.entity';
import { Repository } from 'typeorm';
@Injectable()
export class UserService {
  constructor(
    @InjectRepository(User) private readonly user: Repository<User>) { }
  async login(userDto: UserDto) {
    const userInfo = await this.user.findOne({
      where: {
        username: userDto.username,
        password: userDto.password,
      },
    })
    return userInfo;
  }

  async register(userDto: UserDto) {
    const existingUser = await this.user.findOne({
      where: {
        username: userDto.username,
      },
    });
    if (existingUser) {
      return '用户名已存在';
    }
    const data = new User();
    data.username = userDto.username;
    data.password = userDto.password;
    return this.user.save(data);
  }
}

很明显没有使用sql语句,但是也完成了sql操作;

在另一个项目中使用的是

user模块中的user.model.ts中代码如下:

复制代码
import { Column, Model, Table } from 'sequelize-typescript';

@Table
export class User extends Model<User> {
  @Column
  username: string;
  @Column
  password: string;
  @Column
  avatar: string;
}

在user.service.ts中代码如下:

复制代码
import { Injectable } from '@nestjs/common';
import { CreateUserDto } from './dto/create-user.dto';
import { InjectModel } from '@nestjs/sequelize';
import { User } from './model/user.model';
@Injectable()
export class UserService {
  constructor(@InjectModel(User) private userModel: typeof User,) {

  }
  async create(createUserDto: CreateUserDto) {
    let res = await this.userModel.build({
      ...createUserDto
    })
    await res.save()
    return res
  }
  async findAll() {
    let res = await this.userModel.findAll()
    return res
  }
  async find(createUserDto: CreateUserDto) {
    let res = await this.userModel.findOne({
      where: {
        ...createUserDto
      }
    })
    return res
  }
  async findOne(username: string) {
    let res = await this.userModel.findOne({
      where: {
        username
      }
    })
    return res !== null ? res : null
  }
  async uploadAvatar(username: string, avatar: string) {
    let res = await this.userModel.update({
      avatar
    }, {
      where: {
        username: username
      }
    })
    return {
      code: '200',
      msg: "上传成功",
      data: res
    }
  }
  async hasAvatar(username: string) {
    let res = await this.userModel.findOne({
      where: {
        username: username
      }
    })
    return res.avatar !== null
  }
}
相关推荐
MXN_小南学前端几秒前
基于 Vue3 + ECharts 的数据大屏实例(提供gitHub仓库地址)
前端·javascript·echarts
三品吉他手会点灯4 分钟前
C语言学习笔记 - 18.C编程预备计算机专业知识 - 什么是变量
c语言·开发语言·笔记·学习
宁雨桥8 分钟前
for of,for in以及传统for循环的区别与不同场景下的使用选择
前端·javascript
好奇龙猫9 分钟前
[大学院-python-base gammer learning2: python base programming ]
开发语言·python
海盗123428 分钟前
C#上位机开发-S7协议通信
开发语言·c#
小短腿的代码世界32 分钟前
Qt 2D 绘制实战与性能优化深度解析
开发语言·qt·性能优化
椰羊~王小美36 分钟前
除了前端 JS 配置的国际化,对于 JS 没覆盖到的文本,怎么实现国际化
前端·javascript·状态模式
FeBaby40 分钟前
ReentrantLock 与 synchronized 底层实现对比图解
开发语言·c#
jaycyj40 分钟前
pytest
开发语言·python
A_aspectJ43 分钟前
【Java基础开发】基于 Java Swing +MySQL + JDBC 版实现图书管理系统
java·开发语言·mysql