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
  }
}
相关推荐
小罗和阿泽18 分钟前
接口测试系列 接口自动化测试 pytest框架(三)
开发语言·python·pytest
毕设源码-邱学长7 小时前
【开题答辩全过程】以 基于Java的学校住宿管理系统的设计与实现为例,包含答辩的问题和答案
java·开发语言
bearpping7 小时前
Nginx 配置:alias 和 root 的区别
前端·javascript·nginx
rookieﻬ°8 小时前
PHP框架漏洞
开发语言·php
@大迁世界8 小时前
07.React 中的 createRoot 方法是什么?它具体如何运作?
前端·javascript·react.js·前端框架·ecmascript
January12078 小时前
VBen Admin Select 选择框选中后仍然显示校验错误提示的解决方案
前端·vben
. . . . .8 小时前
前端测试框架:Vitest
前端
xiaotao1318 小时前
什么是 Tailwind CSS
前端·css·css3
炸膛坦客8 小时前
单片机/C/C++八股:(二十)指针常量和常量指针
c语言·开发语言·c++
兑生9 小时前
【灵神题单·贪心】1481. 不同整数的最少数目 | 频率排序贪心 | Java
java·开发语言