[Nestjs] 使用Typeorm 在实体中根据时间生成随机编码

在日常开发中,我们会遇到很多需要自动生成编码的地方,比如订单号,单据号等。

话不多说直接上代码

import { BeforeInsert, Column, Entity } from 'typeorm';

@Entity()
export class YourEntity {
  // 其他字段...

  @Column({ unique: true }) //字段被设置为 unique: true,确保每个编码都是唯一的
  code: string;

  @BeforeInsert() //实体的装饰器方法,用于在保存实体之前生成并设置代码编码。
  generateCode() {
    const currentDate = new Date();
    const datePart = currentDate.toISOString().slice(0, 10).replace(/-/g, '');
    const randomPart = Math.random().toString(36).slice(2, 8).toUpperCase();
    this.code = `${datePart}-${randomPart}`;
  }
}

这样我们保存数据的时候,实体会自动生成code字段编码,大家可以根据自己的需求调整相应的代码!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
nestjs可以和typeorm配合使用typeorm是一个支持多种数据库的ORM框架,可以简化数据库的操作。下面是nestjs如何使用typeorm的步骤: 1. 安装typeorm和相应的数据库驱动,例如mysql, postgres等。可以使用npm命令进行安装: ``` npm install typeorm mysql ``` 2. 在nestjs创建一个数据库模块,可以在模块配置数据库连接等信息。例如: ```typescript import { Module } from '@nestjs/common'; import { TypeOrmModule } from '@nestjs/typeorm'; import { User } from './user.entity'; @Module({ imports: [ TypeOrmModule.forRoot({ type: 'mysql', host: 'localhost', port: 3306, username: 'root', password: 'password', database: 'test', entities: [User], synchronize: true, }), ], }) export class DatabaseModule {} ``` 3. 创建一个实体类,表示数据库的一个表格。例如: ```typescript import { Entity, Column, PrimaryGeneratedColumn } from 'typeorm'; @Entity() export class User { @PrimaryGeneratedColumn() id: number; @Column() name: string; @Column() age: number; @Column() email: string; } ``` 4. 在nestjs的服务使用typeorm进行数据库操作。例如: ```typescript import { Injectable } from '@nestjs/common'; import { InjectRepository } from '@nestjs/typeorm'; import { Repository } from 'typeorm'; import { User } from './user.entity'; @Injectable() export class UserService { constructor( @InjectRepository(User) private readonly userRepository: Repository<User>, ) {} async findAll(): Promise<User[]> { return this.userRepository.find(); } async create(user: User): Promise<User> { return this.userRepository.save(user); } } ``` 这样,nestjs就可以和typeorm配合使用进行数据库操作了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值