从0到100:单位订餐统计小程序开发日记2025

可行性分析

单位订餐统计小程序:员工可快速查看每日菜品及价格。支持多种菜品选择,可按需添加数量,满足不同口味需求。自动记录员工订餐信息,包括菜品、数量、金额等,方便查询历史订单。后台管理功能强大,可实时统计订单数量、金额,生成报表,便于财务结算与管理。同时支持订单修改、取消等操作,灵活适应突发情况。 通过小程序,实现订餐流程高效、透明,提升单位后勤管理效率与员工满意度。

概要设计

数据库设计

c 复制代码
GoodsModel.DB_STRUCTURE = {
	_pid: 'string|true',
	GOODS_ID: 'string|true',

	GOODS_TITLE: 'string|true|comment=标题',
	GOODS_STATUS: 'int|true|default=1|comment=状态 0=未启用,1=使用中',

	GOODS_SALE_CNT: 'int|true|default=0|comment=已购买数量',

	GOODS_CATE_ID: 'string|true|default=0|comment=分类',
	GOODS_CATE_NAME: 'string|false|comment=分类名冗余',

	GOODS_ORDER: 'int|true|default=9999',
	GOODS_VOUCH: 'int|true|default=0',

	GOODS_FORMS: 'array|true|default=[]',
	GOODS_OBJ: 'object|true|default={}',

	GOODS_QR: 'string|false',
	GOODS_VIEW_CNT: 'int|true|default=0',

	GOODS_COMMENT_CNT: 'int|true|default=0',

	GOODS_ADD_TIME: 'int|true',
	GOODS_EDIT_TIME: 'int|true',
	GOODS_ADD_IP: 'string|false',
	GOODS_EDIT_IP: 'string|false',
};
OrderModel.DB_STRUCTURE = {
	_pid: 'string|true',
	ORDER_ID: 'string|true',
	ORDER_USER_ID: 'string|true',

	ORDER_TOTAL_PRICE: 'float|true|default=0|comment=总价',
	ORDER_TOTAL: 'int|true|default=0|comment=数量',
	ORDER_LIST: 'array|true|comment=订单信息',
	ORDER_DAY: 'string|true|comment=日期',

	ORDER_DESC: 'string|false|comment=摘要',

	ORDER_STATUS: 'int|true|default=1|comment=状态 0=未确认,1=成功,9=取消',

	ORDER_ADD_TIME: 'int|true',
	ORDER_EDIT_TIME: 'int|true',
	ORDER_ADD_IP: 'string|false',
	ORDER_EDIT_IP: 'string|false',
};

核心实现

c 复制代码
class OrderService extends BaseProjectService {

	 

	async cancelMyOrder(userId, id) {
		let where = {
			_id: id,
			ORDER_USER_ID: userId,
			ORDER_STATUS: OrderModel.STATUS.COMM
		}
		let order = await OrderModel.getOne(where);
		if (!order) this.AppError('该订单不存在');


		await OrderModel.edit(where, { ORDER_STATUS: 9 });

		// 统计 
		this.statOrder(id);


	}

	async getMyOrderDetail(userId, id) {
		let where = {
			ORDER_USER_ID: userId,
			_id: id,
		}
		return await OrderModel.getOne(where);
	}


	async getMyOrdersList(userId, {
		search, // 搜索条件
		sortType, // 搜索菜单
		sortVal, // 搜索菜单
		orderBy, // 排序
		whereEx, //附加查询条件
		page,
		size,
		isTotal = true,
		oldTotal
	}) {

		orderBy = orderBy || {
			'ORDER_ADD_TIME': 'desc'
		};
		let fields = 'ORDER_ID,ORDER_DAY,ORDER_TOTAL,ORDER_TOTAL_PRICE,ORDER_DESC,ORDER_GOODS_ID,ORDER_ADD_TIME,ORDER_GOODS_TITLE,ORDER_GOODS_CNT,ORDER_SCORE,ORDER_STATUS,goods.GOODS_OBJ.cover';

		let where = {};
		where.and = {
			ORDER_USER_ID: userId,
			_pid: this.getProjectId() //复杂的查询在此处标注PID
		};

		if (util.isDefined(search) && search) {
			where.or = [
				{ ORDER_GOODS_TITLE: ['like', search] },
			];

		} else if (sortType && util.isDefined(sortVal)) {
			// 搜索菜单
			switch (sortType) {
				case 'status': {
					where.and.ORDER_STATUS = Number(sortVal);
					break;
				}
			}
		}

		return await OrderModel.getList(where, fields, orderBy, page, size, isTotal, oldTotal);
	}

}

UI设计






后台管理系统






git下载地址

点击下载

相关推荐
幽络源小助理5 分钟前
SpringBoot+小程序高校素拓分管理系统源码 – 幽络源免费分享
spring boot·后端·小程序
Mr -老鬼30 分钟前
移动端跨平台适配技术框架:从发展到展望
android·ios·小程序·uni-app
内存不泄露1 小时前
棋牌预约小程序系统论文
小程序
说私域20 小时前
短视频私域流量池的变现路径创新:基于AI智能名片链动2+1模式S2B2C商城小程序的实践研究
大数据·人工智能·小程序
毕设源码-邱学长21 小时前
【开题答辩全过程】以 基于微信小程序的松辽律所咨询系统的设计与实现为例,包含答辩的问题和答案
微信小程序·小程序
+VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue物流配送中心信息化管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·小程序·课程设计
说私域1 天前
B站内容生态下的私域流量运营创新:基于AI智能名片链动2+1模式与S2B2C商城小程序的融合实践
人工智能·小程序·流量运营
计算机毕设指导61 天前
基于微信小程序的钓鱼论坛系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
qq_12498707531 天前
基于微信小程序的宠物交易平台的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·微信小程序·小程序·毕业设计·计算机毕业设计
计算机毕设指导61 天前
基于微信小程序的精致护肤购物系统【源码文末联系】
java·spring boot·微信小程序·小程序·tomcat·maven·intellij-idea