✨ feat(db): 给GiftCodeDetail添加只读库
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
import BaseModel from './BaseModel';
|
||||
import { index, getModelForClass, prop, DocumentType, modelOptions } from '@typegoose/typegoose';
|
||||
import { index, getModelForClass, prop, DocumentType, modelOptions, mongoose, ReturnModelType } from '@typegoose/typegoose';
|
||||
import { GIFT_GENERATE_TYPE } from '../consts';
|
||||
import { GiftCodeModel, GiftCodeType } from './GiftCode';
|
||||
import { nowSeconds } from '../pubUtils/timeUtil';
|
||||
@@ -55,17 +55,17 @@ export default class GiftCodeDetail extends BaseModel {
|
||||
|
||||
// 根据code
|
||||
public static async findByCode(code: string) {
|
||||
let result: GiftCodeDetailType = await GiftCodeDetailModel.findOne({ code }).lean(true);
|
||||
let result: GiftCodeDetailType = await GiftCodeDetailROModel.findOne({ code }).lean(true);
|
||||
return result;
|
||||
}
|
||||
|
||||
public static async checkHasUsed(roleId: string, id: number) {
|
||||
let result = await GiftCodeDetailModel.exists({ giftId: id, 'record.roleId': roleId });
|
||||
let result = await GiftCodeDetailROModel.exists({ giftId: id, 'record.roleId': roleId });
|
||||
return result;
|
||||
}
|
||||
|
||||
public static async checkOrderHasUsed(id: number, orderId: string) {
|
||||
let result = await GiftCodeDetailModel.exists({ giftId: id, 'record.orderId': orderId });
|
||||
let result = await GiftCodeDetailROModel.exists({ giftId: id, 'record.orderId': orderId });
|
||||
return result;
|
||||
}
|
||||
|
||||
@@ -120,7 +120,7 @@ export default class GiftCodeDetail extends BaseModel {
|
||||
sort[sortField] = -1;
|
||||
}
|
||||
}
|
||||
const result: GiftCodeDetailType[] = await GiftCodeDetailModel.find(searchObj, { _id: 0 }).limit(pageSize).skip((page - 1) * pageSize).sort(sort).lean({ getters: true, virtuals: true });
|
||||
const result: GiftCodeDetailType[] = await GiftCodeDetailROModel.find(searchObj, { _id: 0 }).limit(pageSize).skip((page - 1) * pageSize).sort(sort).lean({ getters: true, virtuals: true });
|
||||
return result;
|
||||
|
||||
}
|
||||
@@ -128,7 +128,7 @@ export default class GiftCodeDetail extends BaseModel {
|
||||
public static async countByCondition(form: SearchGiftCodeDetailParam = {}) {
|
||||
|
||||
let searchObj = this.getSearchObj(form);
|
||||
const result = await GiftCodeDetailModel.count(searchObj);
|
||||
const result = await GiftCodeDetailROModel.count(searchObj);
|
||||
return result;
|
||||
}
|
||||
|
||||
@@ -136,5 +136,12 @@ export default class GiftCodeDetail extends BaseModel {
|
||||
|
||||
export const GiftCodeDetailModel = getModelForClass(GiftCodeDetail);
|
||||
|
||||
export let GiftCodeDetailROModel: ReturnModelType<typeof GiftCodeDetail, {}>;
|
||||
export function loadGiftCodeDetailROModel(connect: mongoose.Connection) {
|
||||
GiftCodeDetailROModel = getModelForClass(GiftCodeDetail, {
|
||||
existingConnection: connect
|
||||
});
|
||||
}
|
||||
|
||||
export interface GiftCodeDetailType extends Pick<DocumentType<GiftCodeDetail>, keyof GiftCodeDetail> { }
|
||||
export type GiftCodeDetailParam = Partial<GiftCodeDetailType>;
|
||||
|
||||
Reference in New Issue
Block a user