封装数据库模块

数据库模块增删改查的封装

	//使用 Promise	解决异步问题
	const  sql = {
		//增:
				//Collection	---	集合名称	{ String类型 }
				//insertObj	---	新增的数据 { Object类型 }
				//
			insert (Collection, insertObj){
				//使用 Promise 解决异步问题
				return new Promise((resolve, reject) => {
				//把数据插入到集合中
					Collection.insertMany(insertObj, (err) => {
					//node中的错误优先回调
					if(err) throw err;
					resolve( );
					})
				})
			},
			//	删
			//Collection	---	集合名称	{ String类型 }
			//deleteObj	---	删除的数据 { Object类型 }
			//type			---	如果传入的值为1,则删除多条数据,否则只删除单条数据,默认为删除单条数据(可选
			//
			delete (Collection, deleteObj, type){
			//使用 Promise 解决异步问题
				return new Promise((resolve, reject) => {
				//设置默认删除单条数据
					let deleteType = 'deleteOne';
					//如果传入的值为1,则删除多条数据,否则为默认删除数量(三目表达式)
					type === 1 ? deleteType = 'deleteMany' : deleteType = 'deleteOne';
					//根据type值删除集合中的数据
					Collection[deleteType](deleteObj, (err) => {
					//node中的错误优先回调
						if(err) throw err;
						resolve( );
						})
					})
				},
			//改
			//Collection	---	集合名称	{ String类型 }
			//updateObj	---	更新的数据 { Object类型 }
			//whereObj	---	更新的条件 { Object类型 }
			//type			---	如果传入的值为1,则更新多条数据,否则只更新单条数据,默认为更新单条数据(可选)
			//
			update (Collection, whereObj, updateObj, type){
				//使用 Promise 解决异步问题
				return new Promise((resolve, reject) => {
				//设置默认更新单条数据
					let updateType = 'updateOne';
					//如果传入的值为1,则更新多条数据,否则为默认更新数量(三目表达式)
					type === 1 ? updateType = 'updateMany' : updateType ='updateOne';
					//根据type值更新集合中的数据
					Collection[updateType](whereObj, updateObj, (err) => {
					//node中的错误优先回调
						if(err) throw err;
						resolve( );
						})
					})
				},
			//查
			//
			//Collection	---	集合名称	{ String类型 }
			//whereObj	---	查询的条件 { Object类型 }
			//showObj	---	显示的数据{ Object类型 }
			//
			find (Collection, whereObj, showObj){
				//使用 Promise 解决异步问题
				return new Promise((resolve, reject) => {
					//根据查询的条件查询集合中的数据并显示
					Collection.find(whereObj, showObj).exec((err, data) => {
					//node中的错误优先回调
						if(err) throw err;
						resolve(data);
						})
					})
				}
				//把封装好的模块暴露出去,供业务逻辑使用 	---	增删改查
			module.exports = sql;
  • 12
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值