摘 要
随着智能手机的普及和移动互联网的快速发展,点单小程序已成为许多餐饮行业提升用户体验和运营效率的重要工具。本文介绍了茶坤奶茶店点单小程序的设计与开发过程,重点阐述了系统架构、功能设计以及基于Node.js技术实现的后台服务部分。通过对茶坤奶茶店的实际需求分析,本文提出了一个涵盖管理员管理功能和用户便捷操作的完整小程序方案。
该小程序分为管理员后台和普通用户前端两个主要模块。管理员后台实现了对用户管理、订单管理、商品管理、通知公告、优惠券等多项功能的管理,方便管理员进行实时监控和控制。前端用户则可以通过小程序浏览奶茶菜单、查看商品信息、添加商品到购物车、进行在线支付,并在订单完成后进行评价和跟踪配送状态。所有操作都通过后台服务进行数据交互,确保了系统的稳定性和高效性。
Node.js作为服务端开发的核心技术,凭借其高效的异步事件驱动模型和强大的网络处理能力,成为该小程序后台服务的理想选择。本文还探讨了在Node.js环境下如何利用Express框架搭建高效的RESTful API,以及如何通过MongoDB实现数据的高效存储与查询。开发过程中,安全性、用户隐私保护以及性能优化等问题也得到了充分考虑。
本研究为小程序的设计与开发提供了一个可行的实践方案,且具有一定的推广价值和应用前景。
关键词:茶坤奶茶店,点单小程序,Node.js,后台服务,系统设计
Abstract
With the popularity of smart phones and the rapid development of mobile Internet, the order applet has become an important tool for many catering industries to improve user experience and operational efficiency. This article introduces the design and development process of the ordering mini program for Chakun Milk Tea Shop, focusing on the system architecture, functional design, and the backend service part implemented based on Node.js technology. Through the analysis of the actual needs of Chakun Milk Tea Shop, this article proposes a complete mini program solution that includes administrator management functions and convenient user operations.
This mini program is divided into two main modules: the administrator backend and the regular user frontend. The administrator backend has implemented management of multiple functions such as user management, order management, product management, notification announcements, coupons, etc., making it convenient for administrators to monitor and control in real-time. Front end users can browse the milk tea menu, view product information, add products to their shopping cart, make online payments, and evaluate and track the delivery status after the order is completed through the mini program. All operations are conducted through backend services for data exchange, ensuring the stability and efficiency of the system.
As the core technology for server-side development, Node.js, with its efficient asynchronous event driven model and powerful network processing capabilities, has become the ideal choice for backend services of this mini program. This article also explores how to use the Express framework to build efficient RESTful APIs in the Node.js environment, as well as how to achieve efficient data storage and querying through MongoDB. During the development process, issues such as security, user privacy protection, and performance optimization have also been fully considered.
This study provides a feasible practical solution for the design and development of mini programs, and has certain promotional value and application prospects.
Keywords:Chakun Milk Tea Shop, ordering mini program, Node.js, Backend services, system design
目录
第1章引言
1.1研究背景与意义
随着移动互联网的迅猛发展,消费者的购物习惯和需求逐渐转向线上。尤其是在餐饮行业,传统的点餐方式逐渐无法满足现代消费者对便捷、高效服务的需求。在这种背景下,点单小程序成为了餐饮行业中提升服务质量和优化运营效率的重要工具。茶坤奶茶店作为一家注重创新和用户体验的奶茶品牌,结合市场需求,决定开发一款专属的点单小程序,旨在为消费者提供更加便捷和高效的点餐方式,同时提升店铺管理的智能化水平。
传统的奶茶店点单方式依赖于人工服务,不仅存在排队等待时间长、点单过程繁琐等问题,还难以实现精准的数据管理和实时订单跟踪。消费者在繁忙的工作或生活中,通常期望能够通过手机快速完成点单,并即时了解订单的状态。通过小程序的设计与开发,不仅能够为消费者提供方便的点单体验,还能为奶茶店提供更高效的订单管理系统。
在竞争激烈的市场环境中,提升客户满意度和忠诚度成为奶茶店持续发展的关键。借助点单小程序,茶坤奶茶店能够更好地管理客户订单,实时调整运营策略,同时实现精准的商品推荐与个性化服务,进而推动销量和品牌影响力的提升。通过对店铺管理的数字化转型,不仅优化了店铺运营效率,还减少了人工成本,提升了管理的透明度和准确性。
总体来说,茶坤奶茶店点单小程序的研究与开发,不仅是顺应餐饮行业发展的趋势,也是推动品牌升级、提升市场竞争力的重要举措。
1.2国内外研究现状
在全球范围内,餐饮行业的数字化转型已经成为一种重要趋势,尤其是在点单方式的创新方面,各大餐饮品牌纷纷探索通过移动应用和小程序提升用户体验和运营效率。随着智能手机和互联网的普及,餐饮行业逐渐将传统的线下点餐模式转向线上服务平台,尤其是通过小程序实现便捷的点单和支付功能,已成为许多餐饮品牌提高市场竞争力的重要手段。
国内的研究主要集中在如何利用移动互联网技术优化餐饮服务。许多学者和企业在餐饮点单系统的设计和开发方面进行了大量的实践和理论研究。比如,部分研究提出了通过小程序实现快速点单和支付的功能,优化了消费者的点餐体验。研究也显示,小程序不仅提升了餐饮店的运营效率,还通过数据采集和分析实现了精准营销和库存管理。此外,部分开发者还探讨了如何通过小程序实现线上支付、会员管理、订单跟踪等功能,以提供更全面的服务。
在国外,餐饮行业数字化的探索同样取得了显著进展。许多国外餐饮品牌通过移动应用和在线点单系统实现了餐饮服务的自动化和数字化。特别是在美国、欧洲等地区,很多餐饮企业已经全面实现了点餐系统的线上化。研究指出,利用智能手机应用与支付系统的结合,不仅提升了顾客体验,还有效降低了餐厅的运营成本。国外的研究还强调了系统的安全性和用户隐私保护问题,这些问题在开发点单小程序时被充分考虑,以确保用户数据的安全性。
国内外的研究表明,餐饮行业通过数字化转型在提升消费者体验、优化餐厅管理和增加盈利能力方面具有重要作用。点单小程序作为餐饮行业数字化转型的核心之一,正逐渐成为餐饮服务提供商的重要工具,能够有效解决传统点餐方式中存在的种种问题,并为餐饮企业提供全新的发展思路。
1.3论文组成结构
论文将分层次经行编排,除去论文摘要致谢文献参考部分,正文部分还会对系统需求做出分析,以及阐述大体的设计和实现的功能,最后罗列部分调测记录,论文主要架构如下:
第一章:引言。第一章主要介绍了课题研究的背景和意义,系统开发的国内外研究现状和本文的组成结构。
第二章:开发工具及相关技术介绍。主要介绍系统开发所采用的工具和技术。
第三章:系统需求分析。主要从系统的用户、功能等方面进行需求分析。
第四章:系统设计。主要对系统框架、系统功能模块、数据库进行功能设计。
第五章:系统实现。主要介绍了系统框架搭建、系统界面的实现。
第六章:系统测试。主要对系统的部分界面进行测试并对主要功能进行测试
第七章:总结与展望。
第2章相关技术介绍
2.1Express介绍
Express是目前流行的基于Node.js运行环境的Web应用程序开发框架,它简洁且灵活,为Web应用程序提供了强大的功能。Express提供了一个轻量级模块,类似于jQuery(封装的工具库),它把Node.js的HTTP模块的功能封装在一个简单易用的接口中,用于扩展HTTP模块的功能,能够轻松地处理服务器的路由、响应、Cookie和HTTP请求的状态[1]。
Express的优势:
(1)简洁的路由定义方式。
(2)简化HTTP请求参数的处理。
(3)提供中间件机制控制HTTP请求。
(4)拥有大量第三方中间件。
(5)支持多种模版引擎。
2.2Node.js介绍
Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。 Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型。
Node 是一个让 JavaScript 运行在服务端的开发平台,它让 JavaScript 成为与PHP、Python、Perl、Ruby 等服务端语言平起平坐的脚本语言。 发布于2009年5月,由Ryan Dahl开发,实质是对Chrome V8引擎进行了封装。
Node对一些特殊用例进行优化,提供替代的API,使得V8在非浏览器环境下运行得更好。V8引擎执行Javascript的速度非常快,性能非常好。 Node是一个基于Chrome JavaScript运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node 使用事件驱动, 非阻塞I/O 模型而得以轻量和高效,非常适合在分布式设备上运行数据密集型的实时应用[2]。
2.3MySQL数据库
MySQL是一种开源关系型数据库管理系统,广泛应用于Web应用和企业级数据存储。MySQL支持结构化查询语言,允许开发者通过标准语句进行数据的创建、读取、更新和删除操作[3]。数据库通过表格形式组织数据,支持数据完整性和约束条件的定义。MySQL的存储引擎机制使得用户可以根据具体需求选择不同的存储引擎,以优化性能和功能。
MySQL具有高性能和可扩展性,支持大规模数据存储和高并发访问。系统提供了丰富的用户权限管理和数据加密安全特性。MySQL能够与多种编程语言和框架兼容,广泛应用于内容管理系统、电子商务平台和数据分析等各种场景。
2.4JavaScript 运行模式
JavaScript是一种属于网络的高级脚本语言,已经被广泛用于Web应用开发,常用来为网页添加各式各样的动态功能,为用户提供更流畅美观的浏览效果。通常JavaScript脚本是通过嵌入在HTML中来实现自身的功能的[4]。
是一种解释性脚本语言(代码不进行预编译)。
主要用来向HTML(标准通用标记语言下的一个应用)页面添加交互行为。
可以直接嵌入HTML页面,但写成单独的js文件有利于结构和行为的分离[5]。
跨平台特性,在绝大多数浏览器的支持下,可以在多种平台下运行(如Windows、Linux、Mac、Android、iOS等)[6]。
JavaScript脚本语言同其他语言一样,有它自身的基本数据类型,表达式和算术运算符及程序的基本程序框架。JavaScript提供了四种基本的数据类型和两种特殊数据类型用来处理数据和文字。而变量提供存放信息的地方,表达式则可以完成较复杂的信息处理。
2.5B/S框架
B/S(Browser/Server)架构是一种基于浏览器和服务器的系统架构模式,用户通过浏览器与服务器进行交互。B/S架构简化了客户端的部署和管理,用户无需在本地安装复杂的软件,只需使用标准浏览器即可访问应用程序。服务器端负责处理业务逻辑和数据存储,客户端则主要负责展示用户界面和数据交互[7]。B/S架构的设计使得系统更新和维护集中在服务器端,降低了维护成本。
B/S架构通常采用Web技术进行实现,包括HTML、CSS和JavaScript等。用户在浏览器中发起请求,服务器响应并返回数据。数据传输通常通过HTTP或HTTPS协议进行,B/S架构的灵活性使其适用于在线购物、信息管理系统和社交网络等各类应用场景[8]。由于其易于扩展性,B/S架构可以方便地支持大规模用户访问,适应不断变化的业务需求。
微信开发者工具是一款专为小程序开发而设计的应用,它不断改进,提供了便捷的操作方式,并且在开发过程中可以通过微信扫描二维码来访问,从而实现快速、准确的小程序开发和调试。
根据用户的需求,我们将采用不同的屏幕大小来制作小程序。
在完成了视图布置之后,可以通过执行编辑功能,快速更改当前的视图界面。
控制台:方便调试打印输出信息。
将代码上传至腾讯服务器,并在审核过程中填写版本号和备注信息,以确保代码的安全性和准确性。
通过查看资源文件,我们可以快速地调整相关项目的文件目录,从而实现断点调试。
使用远程调试技术,无论是在手机端还是PC端,都能够轻松地进行开发工作。
本地数据存储:显示的是本地存储的数据。
通过使用子父层级结构,我们可以更容易地进行视图调试。
微信的代码体积应该保持在2M 以内,而且在开发过程中,应该严格检查合法域名信息,并且为小程序的后台配置服务器域名。
微信开发者工具已经成为了开发过程中不可或缺的一部分,并且正在不断地改进和完善。
2.7小程序框架介绍
这款微信小程序的设计旨在帮助用户快速、便捷地创建出一款拥有完全独特 特色的应用。它由一套完善的框架结构,将用户界面、操作界面、功能界面等多种功能完美结合,使用户只需要一点点的操作,就能轻松实现微信小程序的创建。框架的核心功能是一个快速的数据绑定机制,它能够轻松地将用户的信息和界面进行一致性的管理。它不仅支持对用户信息的实时监控,还能够根据用户的需求,实现对界面的快速调整和优化,从而使用户能够轻松地构建强大的微信小程序。
第3章系统分析
3.1可行性分析
开发任何一个系统,都要对其可行性进行分析,对其时间和资源上的限制进行考虑,这样可以减少系统开发的风险。同时,分析之后不仅能够合理的运用人力,还能在各方面资源的消耗上得到节省。下面就对技术、经济和操作三个方面来介绍。
3.1.1技术可行性
茶坤奶茶店点单小程序具有较高的技术可行性。首先,Node.js作为一种高效的服务器端运行环境,具备非阻塞I/O和事件驱动的特性,能够在高并发情况下保持系统的高性能,适应茶坤奶茶店点单小程序的实时数据处理需求。Express框架简化了Web应用的开发,提供了灵活的路由和中间件支持,确保了后台逻辑的快速实现。MySQL作为成熟的关系型数据库,能够高效地管理和查询大量的数据,保证了数据的完整性与一致性。通过这些技术的结合,系统能够提供稳定、可靠的服务,同时具有良好的扩展性和维护性,满足茶坤奶茶店点单小程序未来的增长需求。
3.1.2经济可行性
茶坤奶茶店点单小程序在经济上具有较高的可行性。采用Node.js和Express框架进行开发,可以大大减少开发时间和人力成本,同时由于这两者都是开源技术,避免了昂贵的商业软件授权费用。MySQL作为一款广泛应用的开源数据库,其成本较低且支持高效的数据管理,能够满足系统的存储需求而不增加额外开销。此外,系统的模块化设计与高效的性能支持,意味着平台能够处理大量用户和租赁数据,提升运营效率,进而降低了后期维护和扩展的成本。因此,从初期开发到长期运营,系统的经济性都表现出较强的竞争力,为茶坤奶茶店点单小程序提供了低成本、高回报的解决方案。
3.1.3操作可行性
茶坤奶茶店点单小程序在操作上具有较高的可行性。首先,Node.js和Express框架的广泛应用使得开发人员能够快速上手,开发周期短且易于维护。系统采用的前后端分离架构,前端与后端通过API进行高效通信,简化了操作流程,提升了用户体验。同时,MySQL数据库的管理和查询操作直观且稳定,能够保证数据的准确性和实时性。对于管理员和用户而言,系统界面设计简洁直观,操作流程清晰,且通过权限控制,确保了不同角色的操作权限。系统的可扩展性和易于升级的特性,也为后期操作的灵活调整提供了保障。因此,该系统在日常操作中具备高效、稳定且易于管理的特点,确保了平台的顺利运行。
综上所述,茶坤奶茶店点单小程序在技术、经济、操作三个方面都是完全可行的。
3.2系统功能需求
在系统开发设计前,应该对功能做初步设想,清楚这个管理系统有什么板块,每个板块有什么功能,整体的设计是否满足使用者的需求,接着对所开发的系统功能进行的详细分析总结,从而设计出完整的系统并将其实现。用户与开发人员的交流分析,使其达到最佳理解程度,使系统功能达到最佳。
普通用户用例图如下所示。

图3-1 普通用户用例图
管理员用例图如下所示。

图3-2 管理员用例图
通过对用例图的分析和调查,根据本系统的实际需要,从用户角度提出需求功能如下:
1. 普通用户功能描述
首页:用户进入小程序后,看到的主界面,展示店铺的各类饮品、优惠活动和推荐商品。
购物车:用户可以将选中的商品添加到购物车中,便于统一结算。
奶茶信息差:提供奶茶相关的详细资讯信息,包括营养成分、口感、配料等,让用户能够做出更好的购买决策。
商品信息:用户可以查看奶茶及其他商品的详细介绍,包括价格、图片、规格等。
网站公告:展示店铺的重要公告、活动通知等,确保用户随时了解店铺动态。
我的:
基本信息:用户可以查看和更新个人资料,包括用户名、手机号、邮箱等。
收货地址:用户可以管理自己的收货地址,添加或修改配送地址。
收藏:用户可以收藏自己喜爱的奶茶商品,方便日后快速购买。
订单:用户可以查看自己的历史订单,并进行相关操作如取消、退款等。
购物车:查看和管理购物车中的商品。
我的优惠券:查看和使用用户拥有的优惠券,享受折扣优惠。
订单跟踪:用户可以查看订单的实时状态,了解订单的处理进度。
订单评价:用户可以对已完成的订单进行评价,包括评分、评论等。
订单通知:接收与订单相关的实时通知,如支付成功、配送中、订单已送达等。
订单配送:用户可以跟踪自己订单的配送状态,确保及时收到商品。
2.管理员功能描述
后台首页:管理员登录后可以访问的主界面,展示关键的运营数据,如订单数量、销售总额、用户活动等。
系统用户:管理员可以查看和管理系统中的用户信息,进行账号激活、禁用、权限分配等操作。
订单跟踪管理:管理员可以查看订单的处理进度,如支付状态、配送状态、订单取消等,并进行相关操作。
订单评价管理:管理员可以查看和管理用户对订单的评价,删除不良评论或响应用户反馈。
订单通知管理:管理员可以设置和发送与订单相关的通知信息,例如订单确认、配送通知、退款处理等。
系统管理(轮播图):管理员可以更新小程序首页的轮播图,展示特定的广告、促销活动或新品推荐。
通知公告管理:管理员可以发布系统公告或通知,通知用户有关店铺的最新动态、促销活动、节假日休息等信息。
资源管理(奶茶资讯、资讯分类):管理员可以管理奶茶资讯内容及其分类,向用户发布关于奶茶的文章、新闻和相关资讯。
商城管理:
商品信息管理:管理员可以管理所有奶茶店铺中的商品信息,包括奶茶的名称、价格、库存等。
分类列表管理:管理员可以设置和更新商品的分类,如饮品类别、口味类型等,方便用户浏览。
订单列表管理:管理员可以查看所有用户的订单历史,并进行相应的订单处理。
订单配送管理:管理员可以跟踪订单配送状态,分配配送任务并确保及时送达。
优惠券管理:管理员可以创建、管理并发放优惠券,帮助提升销售和客户忠诚度。
会员等级管理:管理员可以设置不同的会员等级,并通过积分、购买历史等标准为用户提供不同的权益和折扣。
3.3系统性能需求
评判一个系统好坏的一项重要指标就是性能,下面是对此系统的一些性能进行阐述。
1.系统的安全性和稳定性: 茶坤奶茶店点单小程序在管理权限上有着严格的控制,即想登录此平台进行操作,则必须要有操作权限,没有权限的用户是不可能登录平台查看任何的信息和数据,从而确保了系统的安全性。
2.数据的完整性和准确性:第一个是各项记录信息的完整性,信息记录的内容可以为空;第二个是各项信息数据之间相互联系的准确性;第三个是数据在不同记录信息的一致性
3.用户操作系统简单方便:在系统开发中按照“简单易用”的原则,能够使用户对系统的使用一目了然,既能保证用户使用,同时又能保证维护人员方便维护。
3.4 系统流程分析
3.4.1用户登录流程
对于系统的安全性的第一关,就是用户想要进入系统,必须通过登录窗口,输入自己的登录信息才可以进行登录,用户输入的信息准确无误后才可以进入到操作系统界面,进行功能模块的相对应操作,如果用户输入的信息不正确,则窗口出现提示框,用户登录失败,返回到第一步进行重新输入,如图3-3所示。
图3-3登录操作流程图
3.4.2信息添加流程
对于茶坤奶茶店点单小程序,需要随时添加所需要的数据信息,对于用户添加信息,需要根据添加界面,根据选框的内容进行填写所要添加的数据信息,信息输入完成后判断数据信息是否符合要求,符合要求则添加完成,用户所添加的信息不符合要求,则需要返回到第一步,重新输入数据信息,再进行判断操作,如图3-4所示。

图3-4信息添加流程图
3.4.3信息删除流程
不管是哪个用户角色进入到系统操作界面,都可以进行不同的信息内容的操作功能,对用系统数据信息的删除,用户一旦将信息删除,那么该删除的数据信息将无法恢复,所以用户在对数据删除时,一定判断删除的内容是否是确定要删除的,确定无误后选择确定删除操作,如图3-5所示。

图3-5信息删除流程图
3.4.4业务流程图
业务流程图既反映了内部业务间的相互联系。茶坤奶茶店点单小程序须支撑整个机构不同层面的多种职能,而各功能模块间存在着多种关联信息,组成一个有机整体,并针对信息自身特点和面临的现实条件,对系统进行业务流程图设计。系统通过流程的顺畅和高效,实现了需求的满足和系统管理的便捷,提升了系统的运行效率和用户体验。茶坤奶茶店点单小程序的业务流程如下图所示。
用户购买奶茶业务流程如下图3-6所示。

图3-6用户购买奶茶业务流程图
第4章系统设计
4.1系统体系结构
选择B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式。适合在互联网上进行操作,只要用户能连网,任何时间、任何地点都可以进行系统的操作使用。系统工作原理图如图4-1所示:

图4-1 系统工作原理图
其最终前后台交互原理如图4-2所示。

图4-2前后台交互原理
具体交互流程为:浏览器中执行具体操作,操作命令将生成一个do方法。该方法使得浏览器能够访问后台中的Controller层,Controller层由于业务上的需要执行进而访问Service层。Service层收到指令后将会去调用内部DAO层的接口。接口将会和MyBatis层下的一个SQL语句相对接。对接好之后进而访问MySql数据库。更新底层数据,然后将数据同步回MyBatis层,同步变化后的数据将通过DAO层接口,Service层和后台Controller层,直观反映到浏览器页面上。
4.2总体结构设计
茶坤奶茶店点单小程序的整体结构设计如下图所示。

图4-3系统功能结构图
4.3数据库设计
在进行数据库设计时,概念设计帮助明确系统的整体结构和需求。在这一阶段,需要确定实体、属性以及它们之间的关系,为后续的数据库表设计奠定基础。接下来,将深入探讨数据库表设计的具体细节,实现更高效的数据存储和管理。
4.3.1概念设计
概念设计是数据库设计的第一步,其主要目标是对系统的数据需求进行全面的理解和抽象[9]。在这一阶段,通过建立实体-关系模型(ER模型)来识别系统中的关键实体、属性及其相互关系。概念设计的输出是一个清晰的ER图,作为后续数据库表设计的基础。以下将展示系统的全局E-R图。

图4-4数据库E-R图
4.3.2数据库表设计
这一阶段的重点是将概念模型转换为实际的数据库结构,包括表的创建、字段的定义及数据类型的选择。每个实体通常对应于数据库中的一张表,而实体的属性则转化为表的列表[10]。以下是系统的数据库表设计展示。
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | token_id | int | 是 | 是 | 临时访问牌ID | |
| 2 | token | varchar | 64 | 否 | 否 | 临时访问牌 |
| 3 | info | text | 65535 | 否 | 否 | 信息 |
| 4 | maxage | int | 是 | 否 | 最大寿命:默认2小时 | |
| 5 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 6 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 7 | user_id | int | 是 | 否 | 用户编号 |
表 4-2-address(收货地址)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | address_id | int | 是 | 是 | 收货地址 | |
| 2 | name | varchar | 32 | 否 | 否 | 姓名 |
| 3 | phone | varchar | 13 | 否 | 否 | 手机 |
| 4 | postcode | varchar | 8 | 否 | 否 | 邮编 |
| 5 | address | varchar | 255 | 是 | 否 | 地址 |
| 6 | user_id | mediumint | 是 | 否 | 用户ID | |
| 7 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 8 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 9 | default | tinyint | 是 | 否 | 默认判断 |
表 4-3-article(文章)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | article_id | mediumint | 是 | 是 | 文章id | |
| 2 | title | varchar | 125 | 是 | 是 | 标题 |
| 3 | type | varchar | 64 | 是 | 否 | 文章分类 |
| 4 | hits | int | 是 | 否 | 点击数 | |
| 5 | praise_len | int | 是 | 否 | 点赞数 | |
| 6 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 7 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 8 | source | varchar | 255 | 否 | 否 | 来源 |
| 9 | url | varchar | 255 | 否 | 否 | 来源地址 |
| 10 | tag | varchar | 255 | 否 | 否 | 标签 |
| 11 | content | longtext | 4294967295 | 否 | 否 | 正文 |
| 12 | img | varchar | 255 | 否 | 否 | 封面图 |
| 13 | description | text | 65535 | 否 | 否 | 文章描述 |
表 4-4-article_type(文章分类)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | type_id | smallint | 是 | 是 | 分类ID | |
| 2 | display | smallint | 是 | 否 | 显示顺序 | |
| 3 | name | varchar | 16 | 是 | 否 | 分类名称 |
| 4 | father_id | smallint | 是 | 否 | 上级分类ID | |
| 5 | description | varchar | 255 | 否 | 否 | 描述 |
| 6 | icon | text | 65535 | 否 | 否 | 分类图标 |
| 7 | url | varchar | 255 | 否 | 否 | 外链地址 |
| 8 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 9 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-5-auth(用户权限管理)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | auth_id | int | 是 | 是 | 授权ID | |
| 2 | user_group | varchar | 64 | 否 | 否 | 用户组 |
| 3 | mod_name | varchar | 64 | 否 | 否 | 模块名 |
| 4 | table_name | varchar | 64 | 否 | 否 | 表名 |
| 5 | page_title | varchar | 255 | 否 | 否 | 页面标题 |
| 6 | path | varchar | 255 | 否 | 否 | 路由路径 |
| 7 | parent | varchar | 64 | 否 | 否 | 父级菜单 |
| 8 | parent_sort | int | 是 | 否 | 父级菜单排序 | |
| 9 | position | varchar | 32 | 否 | 否 | 位置 |
| 10 | mode | varchar | 32 | 是 | 否 | 跳转方式 |
| 11 | add | tinyint | 是 | 否 | 是否可增加 | |
| 12 | del | tinyint | 是 | 否 | 是否可删除 | |
| 13 | set | tinyint | 是 | 否 | 是否可修改 | |
| 14 | get | tinyint | 是 | 否 | 是否可查看 | |
| 15 | field_add | text | 65535 | 否 | 否 | 添加字段 |
| 16 | field_set | text | 65535 | 否 | 否 | 修改字段 |
| 17 | field_get | text | 65535 | 否 | 否 | 查询字段 |
| 18 | table_nav_name | varchar | 500 | 否 | 否 | 跨表导航名称 |
| 19 | table_nav | varchar | 500 | 否 | 否 | 跨表导航 |
| 20 | option | text | 65535 | 否 | 否 | 配置 |
| 21 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 22 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-6-cart(购物车)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | cart_id | int | 是 | 是 | 购物车ID | |
| 2 | title | varchar | 64 | 否 | 否 | 标题 |
| 3 | img | varchar | 255 | 是 | 否 | 图片 |
| 4 | user_id | int | 是 | 否 | 用户ID | |
| 5 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 6 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 7 | state | int | 是 | 否 | 状态:使用中,已失效 | |
| 8 | price | double | 是 | 否 | 单价 | |
| 9 | price_ago | double | 是 | 否 | 原价 | |
| 10 | price_count | double | 是 | 否 | 总价 | |
| 11 | num | int | 是 | 否 | 数量 | |
| 12 | goods_id | mediumint | 是 | 是 | 商品id | |
| 13 | type | varchar | 64 | 是 | 否 | 商品分类 |
| 14 | description | varchar | 255 | 否 | 否 | 描述 |
表 4-7-code_token(验证码)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | code_token_id | int | 是 | 是 | 验证码ID | |
| 2 | token | varchar | 255 | 否 | 否 | 令牌 |
| 3 | code | varchar | 255 | 否 | 否 | 验证码 |
| 4 | expire_time | timestamp | 是 | 否 | 失效时间 | |
| 5 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 6 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-8-collect(收藏)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | collect_id | int | 是 | 是 | 收藏ID | |
| 2 | user_id | int | 是 | 是 | 收藏人ID | |
| 3 | source_table | varchar | 255 | 否 | 否 | 来源表 |
| 4 | source_field | varchar | 255 | 否 | 否 | 来源字段 |
| 5 | source_id | int | 是 | 否 | 来源ID | |
| 6 | title | varchar | 255 | 否 | 否 | 标题 |
| 7 | img | varchar | 255 | 否 | 否 | 封面 |
| 8 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 9 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-9-comment(评论)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | comment_id | int | 是 | 是 | 评论ID | |
| 2 | user_id | int | 是 | 是 | 评论人ID | |
| 3 | reply_to_id | int | 是 | 否 | 回复评论ID | |
| 4 | content | longtext | 4294967295 | 否 | 否 | 内容 |
| 5 | nickname | varchar | 255 | 否 | 否 | 昵称 |
| 6 | avatar | varchar | 255 | 否 | 否 | 头像地址 |
| 7 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 8 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 9 | source_table | varchar | 255 | 否 | 否 | 来源表 |
| 10 | source_field | varchar | 255 | 否 | 否 | 来源字段 |
| 11 | source_id | int | 是 | 否 | 来源ID |
表 4-10-commodity_information(商品信息)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | commodity_information_id | int | 是 | 是 | 商品信息ID | |
| 2 | purchase_instructions | varchar | 64 | 否 | 否 | 购买须知 |
| 3 | collect_len | int | 是 | 否 | 收藏数 | |
| 4 | comment_len | int | 是 | 否 | 评论数 | |
| 5 | cart_title | varchar | 125 | 否 | 否 | 标题 |
| 6 | cart_img | text | 65535 | 否 | 否 | 封面图 |
| 7 | cart_description | varchar | 255 | 否 | 否 | 描述 |
| 8 | cart_price_ago | double | 是 | 否 | 原价 | |
| 9 | cart_price | double | 是 | 否 | 卖价 | |
| 10 | cart_inventory | int | 是 | 否 | 商品库存 | |
| 11 | cart_type | varchar | 64 | 是 | 否 | 商品分类 |
| 12 | cart_content | longtext | 4294967295 | 否 | 否 | 正文 |
| 13 | cart_img_1 | text | 65535 | 否 | 否 | 主图1 |
| 14 | cart_img_2 | text | 65535 | 否 | 否 | 主图2 |
| 15 | cart_img_3 | text | 65535 | 否 | 否 | 主图3 |
| 16 | cart_img_4 | text | 65535 | 否 | 否 | 主图4 |
| 17 | cart_img_5 | text | 65535 | 否 | 否 | 主图5 |
| 18 | create_time | datetime | 是 | 否 | 创建时间 | |
| 19 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-11-coupon(优惠券)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | coupon_id | int | 是 | 是 | 优惠券ID | |
| 2 | coupon_user_id | int | 否 | 否 | 优惠券用户ID | |
| 3 | coupon_user_auth | varchar | 255 | 否 | 否 | 优惠券用户 |
| 4 | coupon_name | varchar | 255 | 否 | 否 | 优惠券名称 |
| 5 | coupon_price | int | 否 | 否 | 优惠券价格 | |
| 6 | coupon_price1 | int | 否 | 否 | 优惠券券后价格 | |
| 7 | coupon_time | varchar | 255 | 否 | 否 | 优惠券时间 |
| 8 | coupon_type | varchar | 255 | 否 | 否 | 优惠券类型 |
| 9 | create_time | timestamp | 否 | 否 | 创建时间 | |
| 10 | update_time | timestamp | 否 | 否 | 更新时间 |
表 4-12-coupon_user(用户优惠券)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | id | int | 是 | 是 | 用户优惠券ID | |
| 2 | user_id | int | 否 | 否 | 用户ID | |
| 3 | coupon_id | int | 否 | 否 | 优惠券ID | |
| 4 | is_use | int | 否 | 否 | 是否使用 | |
| 5 | coupon_user_id | int | 否 | 否 | 用户优惠券ID |
表 4-13-goods(商品信息)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | goods_id | mediumint | 是 | 是 | 产品ID | |
| 2 | title | varchar | 125 | 否 | 否 | 标题 |
| 3 | img | text | 65535 | 否 | 否 | 封面图:用于显示于产品列表页 |
| 4 | description | varchar | 255 | 否 | 否 | 描述 |
| 5 | price_ago | double | 是 | 否 | 原价 | |
| 6 | price | double | 是 | 否 | 卖价 | |
| 7 | sales | int | 是 | 否 | 销量 | |
| 8 | inventory | int | 是 | 否 | 商品库存 | |
| 9 | type | varchar | 64 | 是 | 否 | 商品分类 |
| 10 | hits | int | 是 | 否 | 点击量 | |
| 11 | content | longtext | 4294967295 | 否 | 否 | 正文 |
| 12 | img_1 | text | 65535 | 否 | 否 | 主图1 |
| 13 | img_2 | text | 65535 | 否 | 否 | 主图2 |
| 14 | img_3 | text | 65535 | 否 | 否 | 主图3 |
| 15 | img_4 | text | 65535 | 否 | 否 | 主图4 |
| 16 | img_5 | text | 65535 | 否 | 否 | 主图5 |
| 17 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 18 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 19 | customize_field | text | 65535 | 否 | 否 | 自定义字段 |
| 20 | source_table | varchar | 255 | 否 | 否 | 来源表 |
| 21 | source_field | varchar | 255 | 否 | 否 | 来源字段 |
| 22 | source_id | int | 是 | 否 | 来源ID | |
| 23 | user_id | int | 否 | 否 | 添加人 |
表 4-14-goods_type(商品类型)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | type_id | int | 是 | 是 | 商品分类ID | |
| 2 | father_id | smallint | 是 | 否 | 上级分类ID | |
| 3 | name | varchar | 255 | 否 | 否 | 商品名称 |
| 4 | desc | varchar | 255 | 否 | 否 | 描述 |
| 5 | icon | varchar | 255 | 否 | 否 | 图标 |
| 6 | source_table | varchar | 255 | 否 | 否 | 来源表 |
| 7 | source_field | varchar | 255 | 否 | 否 | 来源字段 |
| 8 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 9 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-15-hits(用户点击)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | hits_id | int | 是 | 是 | 点赞ID | |
| 2 | user_id | int | 是 | 否 | 点赞人 | |
| 3 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 4 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 5 | source_table | varchar | 255 | 否 | 否 | 来源表 |
| 6 | source_field | varchar | 255 | 否 | 否 | 来源字段 |
| 7 | source_id | int | 是 | 否 | 来源ID |
表 4-16-logistics_delivery(物流配送)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | logistics_delivery_id | int | 是 | 是 | 物流配送ID | |
| 2 | order_number | varchar | 64 | 否 | 否 | 订单号 |
| 3 | product_name | varchar | 64 | 否 | 否 | 商品名称 |
| 4 | purchase_quantity | varchar | 64 | 否 | 否 | 购买数量 |
| 5 | total_transaction_amount | double | 否 | 否 | 交易总额 | |
| 6 | the_date_of_issuance | date | 否 | 否 | 发货日期 | |
| 7 | delivery_number | varchar | 30 | 否 | 否 | 配送订单 |
| 8 | ordinary_users | int | 否 | 否 | 普通用户 | |
| 9 | shipping_address | varchar | 64 | 否 | 否 | 收货地址 |
| 10 | delivery_status | varchar | 64 | 否 | 否 | 配送状态 |
| 11 | signing_status | varchar | 64 | 否 | 否 | 签收状态 |
| 12 | recommend | int | 是 | 否 | 智能推荐 | |
| 13 | contact_name | varchar | 255 | 否 | 否 | 联系人名字 |
| 14 | merchant_id | int | 否 | 否 | 商家id | |
| 15 | create_time | datetime | 是 | 否 | 创建时间 | |
| 16 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-17-notice(公告)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | notice_id | mediumint | 是 | 是 | 公告ID | |
| 2 | title | varchar | 125 | 是 | 否 | 标题 |
| 3 | content | longtext | 4294967295 | 否 | 否 | 正文 |
| 4 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 5 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-18-order(订单)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | order_id | int | 是 | 是 | 订单ID | |
| 2 | order_number | varchar | 64 | 否 | 否 | 订单号 |
| 3 | goods_id | mediumint | 是 | 是 | 商品ID | |
| 4 | title | varchar | 255 | 否 | 否 | 商品标题 |
| 5 | img | varchar | 255 | 否 | 否 | 商品图片 |
| 6 | price | double | 是 | 否 | 价格 | |
| 7 | price_ago | double | 是 | 否 | 原价 | |
| 8 | num | int | 是 | 否 | 数量 | |
| 9 | price_count | double | 是 | 否 | 总价 | |
| 10 | norms | varchar | 255 | 否 | 否 | 规格 |
| 11 | type | varchar | 64 | 是 | 否 | 商品分类 |
| 12 | contact_name | varchar | 32 | 否 | 否 | 联系人姓名 |
| 13 | contact_email | varchar | 125 | 否 | 否 | 联系人邮箱 |
| 14 | contact_phone | varchar | 11 | 否 | 否 | 联系人手机 |
| 15 | contact_address | varchar | 255 | 否 | 否 | 收件地址 |
| 16 | postal_code | varchar | 9 | 否 | 否 | 邮政编码 |
| 17 | user_id | int | 是 | 否 | 买家ID | |
| 18 | merchant_id | mediumint | 是 | 否 | 商家ID | |
| 19 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 20 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 21 | description | varchar | 255 | 否 | 否 | 描述 |
| 22 | state | varchar | 16 | 是 | 否 | 订单状态:待付款,待发货,待签收,已签收,待退款,已退款,已拒绝,已完成 |
| 23 | remark | text | 65535 | 否 | 否 | 订单备注 |
| 24 | delivery_state | varchar | 16 | 否 | 否 | 发货状态:未配送,已配送 |
| 25 | vip_discount | double | 否 | 否 | 折扣 |
表 4-19-order_evaluation(订单评价)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | order_evaluation_id | int | 是 | 是 | 订单评价ID | |
| 2 | ordinary_user | int | 否 | 否 | 普通用户 | |
| 3 | self_coding | varchar | 64 | 否 | 否 | 自提编码 |
| 4 | name_of_commodity | varchar | 64 | 否 | 否 | 商品名称 |
| 5 | order_number | varchar | 64 | 否 | 否 | 订单编号 |
| 6 | commodity_price | double | 否 | 否 | 商品价格 | |
| 7 | purchase_quantity | varchar | 64 | 否 | 否 | 购买数量 |
| 8 | evaluation_picture | varchar | 255 | 否 | 否 | 评价图片 |
| 9 | evaluation_content | text | 65535 | 否 | 否 | 评价内容 |
| 10 | create_time | datetime | 是 | 否 | 创建时间 | |
| 11 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 12 | source_table | varchar | 255 | 否 | 否 | 来源表 |
| 13 | source_id | int | 否 | 否 | 来源ID | |
| 14 | source_user_id | int | 否 | 否 | 来源用户 |
表 4-20-order_notification(订单通知)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | order_notification_id | int | 是 | 是 | 订单通知ID | |
| 2 | ordinary_user | int | 否 | 否 | 普通用户 | |
| 3 | self_coding | varchar | 64 | 否 | 否 | 自提编码 |
| 4 | name_of_commodity | varchar | 64 | 否 | 否 | 商品名称 |
| 5 | order_number | varchar | 64 | 否 | 否 | 订单编号 |
| 6 | commodity_price | double | 否 | 否 | 商品价格 | |
| 7 | purchase_quantity | varchar | 64 | 否 | 否 | 购买数量 |
| 8 | order_status | varchar | 64 | 否 | 否 | 订单状态 |
| 9 | notification_content | text | 65535 | 否 | 否 | 通知内容 |
| 10 | create_time | datetime | 是 | 否 | 创建时间 | |
| 11 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 12 | source_table | varchar | 255 | 否 | 否 | 来源表 |
| 13 | source_id | int | 否 | 否 | 来源ID | |
| 14 | source_user_id | int | 否 | 否 | 来源用户 |
表 4-21-order_tracking(订单跟踪)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | order_tracking_id | int | 是 | 是 | 订单跟踪ID | |
| 2 | ordinary_user | int | 否 | 否 | 普通用户 | |
| 3 | self_coding | varchar | 64 | 是 | 是 | 自提编码 |
| 4 | name_of_commodity | varchar | 64 | 否 | 否 | 商品名称 |
| 5 | order_number | varchar | 64 | 否 | 否 | 订单编号 |
| 6 | commodity_price | double | 否 | 否 | 商品价格 | |
| 7 | purchase_quantity | varchar | 64 | 否 | 否 | 购买数量 |
| 8 | order_status | varchar | 64 | 否 | 否 | 订单状态 |
| 9 | order_description | text | 65535 | 否 | 否 | 订单描述 |
| 10 | order_evaluation_limit_times | int | 是 | 否 | 评价限制次数 | |
| 11 | order_notification_limit_times | int | 是 | 否 | 通知限制次数 | |
| 12 | create_time | datetime | 是 | 否 | 创建时间 | |
| 13 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-22-ordinary_user(普通用户)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | ordinary_user_id | int | 是 | 是 | 普通用户ID | |
| 2 | user_name | varchar | 64 | 否 | 否 | 用户姓名 |
| 3 | user_gender | varchar | 64 | 否 | 否 | 用户性别 |
| 4 | users_mobile_phone | varchar | 16 | 否 | 否 | 用户手机 |
| 5 | examine_state | varchar | 16 | 是 | 否 | 审核状态 |
| 6 | user_id | int | 是 | 否 | 用户ID | |
| 7 | create_time | datetime | 是 | 否 | 创建时间 | |
| 8 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-23-praise(点赞)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | praise_id | int | 是 | 是 | 点赞ID | |
| 2 | user_id | int | 是 | 是 | 点赞人 | |
| 3 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 4 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 5 | source_table | varchar | 255 | 否 | 否 | 来源表 |
| 6 | source_field | varchar | 255 | 否 | 否 | 来源字段 |
| 7 | source_id | int | 是 | 否 | 来源ID | |
| 8 | status | tinyint | 是 | 否 | 点赞状态:1为点赞,0已取消 |
表 4-24-schedule(日程管理)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | schedule_id | smallint | 是 | 是 | 日程ID | |
| 2 | content | varchar | 255 | 否 | 否 | 日程内容 |
| 3 | scheduled_time | datetime | 否 | 否 | 计划时间 | |
| 4 | user_id | int | 是 | 否 | 用户ID | |
| 5 | create_time | datetime | 否 | 否 | 创建时间 | |
| 6 | update_time | datetime | 否 | 否 | 更新时间 |
表 4-25-score(评分)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | score_id | int | 是 | 是 | 评分ID | |
| 2 | user_id | int | 是 | 否 | 评分人 | |
| 3 | nickname | varchar | 64 | 否 | 否 | 昵称 |
| 4 | score_num | double | 是 | 否 | 评分 | |
| 5 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 6 | update_time | timestamp | 是 | 否 | 更新时间 | |
| 7 | source_table | varchar | 255 | 否 | 否 | 来源表 |
| 8 | source_field | varchar | 255 | 否 | 否 | 来源字段 |
| 9 | source_id | int | 是 | 否 | 来源ID |
表 4-26-slides(轮播图)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | slides_id | int | 是 | 是 | 轮播图ID | |
| 2 | title | varchar | 64 | 否 | 否 | 标题 |
| 3 | content | varchar | 255 | 否 | 否 | 内容 |
| 4 | url | varchar | 255 | 否 | 否 | 链接 |
| 5 | img | varchar | 255 | 否 | 否 | 轮播图 |
| 6 | hits | int | 是 | 否 | 点击量 | |
| 7 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 8 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-27-upload(文件上传)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | upload_id | int | 是 | 是 | 上传ID | |
| 2 | name | varchar | 64 | 否 | 否 | 文件名 |
| 3 | path | varchar | 255 | 否 | 否 | 访问路径 |
| 4 | file | varchar | 255 | 否 | 否 | 文件路径 |
| 5 | display | varchar | 255 | 否 | 否 | 显示顺序 |
| 6 | father_id | int | 否 | 否 | 父级ID | |
| 7 | dir | varchar | 255 | 否 | 否 | 文件夹 |
| 8 | type | varchar | 32 | 否 | 否 | 文件类型 |
表 4-28-user(用户账户)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | user_id | int | 是 | 是 | 用户ID | |
| 2 | state | smallint | 是 | 否 | 账户状态:(1可用|2异常|3已冻结|4已注销) | |
| 3 | user_group | varchar | 32 | 否 | 否 | 所在用户组 |
| 4 | login_time | timestamp | 是 | 否 | 上次登录时间 | |
| 5 | phone | varchar | 11 | 否 | 否 | 手机号码 |
| 6 | phone_state | smallint | 是 | 否 | 手机认证:(0未认证|1审核中|2已认证) | |
| 7 | username | varchar | 16 | 是 | 否 | 用户名 |
| 8 | nickname | varchar | 16 | 否 | 否 | 昵称 |
| 9 | password | varchar | 64 | 是 | 否 | 密码 |
| 10 | | varchar | 64 | 否 | 否 | 邮箱 |
| 11 | email_state | smallint | 是 | 否 | 邮箱认证:(0未认证|1审核中|2已认证) | |
| 12 | avatar | varchar | 255 | 否 | 否 | 头像地址 |
| 13 | open_id | varchar | 255 | 否 | 否 | 针对获取用户信息字段 |
| 14 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 15 | vip_level | varchar | 255 | 否 | 否 | 会员等级 |
| 16 | vip_discount | double | 否 | 否 | 会员折扣 |
表 4-29-user_group(用户组)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | group_id | mediumint | 是 | 是 | 用户组ID | |
| 2 | display | smallint | 是 | 否 | 显示顺序 | |
| 3 | name | varchar | 16 | 是 | 否 | 名称 |
| 4 | description | varchar | 255 | 否 | 否 | 描述 |
| 5 | source_table | varchar | 255 | 否 | 否 | 来源表 |
| 6 | source_field | varchar | 255 | 否 | 否 | 来源字段 |
| 7 | source_id | int | 是 | 否 | 来源ID | |
| 8 | register | smallint | 否 | 否 | 注册位置 | |
| 9 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 10 | update_time | timestamp | 是 | 否 | 更新时间 |
表 4-30-vip_level(论坛分类)
| 编号 | 字段名 | 类型 | 长度 | 是否非空 | 是否主键 | 注释 |
| 1 | vip_level_id | smallint | 是 | 是 | 等级ID | |
| 2 | name | varchar | 255 | 是 | 否 | 等级名称 |
| 3 | discount | double | 是 | 否 | 折扣 | |
| 4 | create_time | timestamp | 是 | 否 | 创建时间 | |
| 5 | update_time | timestamp | 是 | 否 | 更新时间 |
第5章系统实现
5.1登录模块的实现
为确保系统安全性,系统操作员只有在登录界面输入正确的用户名、密码、权限以及验证码,单击“登录”按钮后才能够进入本系统的主界面。登录界面如下图所示。

图5-1登录界面
Login.prototype.api = async function(req) {
var body = req.body;
var obj = await $.services["user"].get_obj({
username: body.username
},{like:false});
if (obj) {
var group = await $.services["user_group"].get_obj({
name:obj.user_group
})
if (group){
if (group.name!=="管理员"){
var sql = "select examine_state from "+ group.source_table +" WHERE user_id = " + obj.user_id;
var userExamine = await $.mysql.run(sql);
if (userExamine && userExamine.length > 0 && userExamine[0].examine_state!=="已通过"){
return {
error: {
code: 70000,
message: "该用户审核未通过"
},
};
}
}
if (obj.state!==1){
return {
error: {
code: 70000,
message: "用户非可用状态,不能登录"
},
};
}
var password = md5(body.password);
if (password === obj.password) {
req.session.user = obj;
var date = Date.parse(new Date());
var token = md5(obj.user_id + "_" + date);
await $.services["access_token"].add({
token,
info: JSON.stringify(obj),
user_id:obj.user_id
});
obj.token = token;
return {
result: {obj}
};
} else {
return {
error: {
code: 70000,
message: "密码错误"
},
};
}
}else {
return {
error: {
code: 70000,
message: "用户组不存在"
},
};
}
} else {
return {
error: {
code: 70000,
message: "账户不存在"
}
};
}
};
5.2 普通用户子系统模块的实现
5.2.1 商品信息模块
用户可以在该版块浏览各种商品信息。系统提供商品分类、品牌筛选、价格区间等功能,用户可以更精确地找到所需产品。每个商品页面提供详细的描述、产品图片、规格信息、价格等,帮助用户做出购买决策。商品信息如下图所示。

图5-2商品信息界面
商品信息添加关键代码如下:
Service.prototype.get_list = async function(query, config) {
var sql = $.mysql.toGetSql(query, Object.assign({}, this.config, config || {}));
return await this.run(sql);
};
5.2.2 订单模块
用户可以查看历史订单和当前订单的详细信息,包括每个订单的状态、预计送达时间、产品明细等。订单界面如下图所示。

图5-3订单界面
5.2.3 购物车模块
展示用户临时选购的产品列表,用户可以在此确认产品数量、价格,或删除不需要的产品。购物车页面如下图所示。

图5-4购物车界面
5.2.4 我的优惠券模块
用户可以查看和使用用户拥有的优惠券,享受折扣优惠。页面如下图所示。

图5-5 我的优惠券界面
5.3 管理员子系统模块的实现
5.3.1 系统用户模块
在“系统用户”模块下,管理员可以管理系统上的用户。管理员可以进行用户的增、删、改、查操作,包括设置权限、修改用户信息等。系统用户页面如下图所示。
图5-6系统用户界面
系统用户的关键代码如下:
Register.prototype.index = async function(req,res) {
var group_list = await $.services["user_group"].get_list({}, Object.assign({}, this.config));
return await res.render(this.config.tpl + "index.html", {
group_list
});
};
Register.prototype.api = async function(req) {
var user = $.services.user;
var body = req.body;
var username = body.username;
var obj = await user.get_obj({
username
});
if (obj) {
return {
error: {
code: 70000,
message: "账户名已存在",
},
};
} else {
var password = md5(body.password);
var nickname = body.nickname;
var user_group = body.user_group;
var email = body.email;
var email_state= body.hasOwnProperty('email_state') ? body.email_state : 0;
var phone = body.phone;
var phone_state= body.hasOwnProperty('phone_state') ? body.phone_state : 0;
var bl_reg = await user.add({
username,
password,
nickname,
user_group,
email,
email_state,
phone,
phone_state
});
if (bl_reg) {
return {
result: "注册成功"
};
} else {
return {
error: {
code: 70000,
message: "注册失败",
},
};
}
}
};
5.3.2订单跟踪管理模块
管理员点击“订单跟踪管理”这一菜单会显示订单跟踪列表和订单跟踪添加两个子菜单,点击“订单跟踪列表”可以查看所有的订单跟踪,还可以进行重置、查询、删除、评价和通知等操作。点击“订单跟踪添加”,管理员可以添加新的订单跟踪信息。页面如下图所示。
图5-7订单跟踪管理界面
新增订单跟踪代码如下:
Controller.prototype.add = async function(ctx) {
var result = await this.service.add(ctx.request.body, this.config);
if (this.service.error) {
return {
error: this.service.error,
};
}
return {
result,
};
};
5.3.3 订单通知管理模块
管理员点击“订单通知管理”这一菜单会显示订单通知列表这个子菜单,点击“订单通知列表”可以查看所有的订单通知,还可以进行重置、查询、删除等操作。界面如下图所示。
图5-8订单通知管理界面
5.3.4系统管理
系统管理:可以查看轮播图详情,以及查询、重置、删除、添加等操作。系统管理界面如下图所示。
图5-9系统管理界面
5.3.5通知公告管理
管理员可以发布通知公告,管理员还可以编辑、删除或修改已发布的公告,确保公告内容的时效性和准确性。通知公告管理界面所示。
图5-10通知公告管理界面
5.3.6商品信息
管理员能够添加、编辑和删除自己销售的奶茶信息,包括名称、品种、规格、价格、库存等详细信息。通过管理奶茶信息,可以确保产品信息的准确性,提升用户的购买体验。商品信息界面所示。
图5-11商品信息界面
5.3.7订单列表
管理员可以查看所有接收到的订单,包括订单的详细信息、状态和用户信息。此功能允许管理员快速处理订单,进行发货、退款和修改等操作,确保交易的顺利进行。订单列表界面界面所示。
图5-12订单列表界面
第6章系统测试
6.1 测试目的
测试的主要目的是确保系统的功能和性能满足预期的需求,同时识别和修复潜在的缺陷。通过系统测试,可以验证各个功能模块的正确性和稳定性,确保系统在不同使用场景下的表现符合设计要求。测试目的包括确认系统功能的完整性、验证数据处理的准确性、评估系统的性能和安全性。测试还可以提高用户满意度,保证用户在使用系统时获得流畅和可靠的体验。通过全面的测试,可以降低后期维护成本,减少系统上线后出现故障的风险,从而保障系统的长期稳定运行。
6.2测试方法
在本系统中,测试方法主要依赖于测试用例的设计与执行。测试用例是根据系统需求文档编写的,覆盖所有功能模块及其边界情况。每个测试用例包含输入数据、预期结果和实际结果的对比,以验证系统的功能是否按预期工作。
常见的测试用例包括功能测试用例、边界测试用例和异常测试用例[11]。功能测试用例针对系统的各项功能进行验证;边界测试用例则侧重于输入数据的边界条件,验证系统在极端情况下是否能够稳定运行;异常测试用例则用于验证系统在处理错误输入或异常情况时的反应。本文选择功能测试用例进行系统测试。
在测试执行过程中,记录每个用例的执行结果,并根据实际结果与预期结果的对比,判断系统是否存在缺陷。通过系统化的测试用例执行,可以有效提高测试的覆盖率和效率,为系统的最终上线提供保障。
6.3测试内容
通过对系统中所含的主要实体对象及其功能操作进行测试用例设计。以下是详细的测试:
表6-1用户注册登录测试表
用户注册登录测试用例:
| 用例说明 | 测试目的 | 测试步骤 | 预期结果 | 输出结果 | 通过情况 |
| 用户注册、登录 | 测试用户正确注册、登录 |
| 用户注册成功,登录成功 | 结果输出符合预期 | 通过 |
表6-2订单配送测试表
订单配送用例:
| 用例说明 | 测试目的 | 测试步骤 | 预期结果 | 输出结果 | 通过情况 |
| 订单配送 | 测试用户订单配送功能 |
| 订单配送成细,生成新的配送信息 | 结果输出符合预期 | 通过 |
表6-3商品信息评论测试表
商品信息评论测试用例:
| 用例说明 | 测试目的 | 测试步骤 | 预期结果 | 输出结果 | 通过情况 |
| 商品信息评论 | 测试用户商品信息评论功能 | 1、在首页点击商品信息并看详情; 2、点击评论,输入相关信息点击提交 | 生成新的评论信息 | 结果输出符合预期 | 通过 |
表6-4商品信息添加测试表
商品信息添加测试用例:
| 用例说明 | 测试目的 | 测试步骤 | 预期结果 | 输出结果 | 通过情况 |
| 商品信息添加测试 | 测试管理员添加商品信息功能 |
| 商品信息添加成功 | 结果输出符合预期 | 通过 |
表6-5系统公告删除测试表
系统公告删除测试用例:
| 用例说明 | 测试目的 | 测试步骤 | 预期结果 | 输出结果 | 通过情况 |
| 系统公告删除测试 | 测试系统公告删除功能 |
| 系统公告删除成功,前端不在展示该系统公告 | 结果输出符合预期 | 通过 |
在本次测试的过程主要针对所有功能下的添加操作,修改操作和删除操作,并以真实数据一一进行相关功能项目的输入,最终能够保证每个项目涉及的功能都是能够正常运行,因此能够保证本次设计的,已实现的功能能够正常运行并且相关数据库的信息也同样保证正确。
结论
经过了几个月的努力,茶坤奶茶店点单小程序终于完成了,虽然在校期间也开发过一些小型的小程序,但是都是在老师的讲解以及辅助下完成的,没有经历过开发之前的需求分析、系统分析,都是直接从系统设计开始的,因此开发茶坤奶茶店点单小程序对我意义重大。
在开发小程序最初,首先对各个茶坤奶茶店点单小程序方面的需求进行调研,了解对于用户来说,开发的平台需要实现哪些功能才能满足各方需求,对需求进行分析;其次选择自己比较熟悉的Nodejs语言,MYSQL数据库来设计开发,通过知网库、学校图书馆等地方查阅、学习这些技术,掌握编程的思想和方法,然后就是对小程序进行分析,从小程序开发的可行性、实现的功能、应该具备的性能以及操作流程方面,对小程序进行全方位的分析,确定最终功能,从而对小程序的功能和数据库进行设计,最后就是小程序的实现以及对实现的功能的测试,确保小程序能够稳定的运行。
在开发的过程中暴露出了自己的很多问题,比如前期的准备还是不够充分,不能完全掌握其操作流程;在开发过程中对Nodejs的编程掌握的还不够熟练以及对系统的环境配置上还存在很多问题,经常会导致项目在运行的时候出现错误。学无止境,通过一边查阅资料一边向导师请教,慢慢的解决了这些问题,在以后的学习、工作者我会更加严谨,通过本项目的开发,我将会受益终生!
参考文献
- 凌杰.Node.js后端全程实战[M].人民邮电出版社:202305.371.
- 唐小燕,刘洪武.Node.js应用开发[M].人民邮电出版社:202111.308.
- 李艳杰.MySQL数据库下存储过程的综合运用研究[J].现代信息科技,2023,7(11):80-82+88.
- 董宁,袁晓曦.JavaScript程序设计[M].人民邮电出版社:202308.265.
- 何勇,王瑶.HTML5+CSS3+JavaScript 网页设计基础与实战[M].人民邮电出版社:202211.262.
- 孙文江,陈义辉.JavaScript交互式网页设计[M].人民邮电出版社:202309.419.
- 刘江涛,王亮亮,吴庆茹,等.基于B/S模式的铁路勘测设计案例信息化管理系统设计与实现[J].铁路计算机应用,2021,30(03):32-35.
- 张丹丹,李弘.基于B/S架构的办公管理系统设计与开发[J].铁路通信信号工程技术,2024,21(09):44-48+106.
- 周晓玉,崔文超.基于Web技术的数据库应用系统设计[J].信息与电脑(理论版),2023,35(09):189-191.
- 马艳艳,吴晓光.计算机软件与数据库的设计策略分析[J].电子技术,2024,53(05):104-105.
- 李俊萌.计算机软件测试技术与开发应用策略分析[J].信息记录材料,2023,24(03):50-52.
- Tural S .Hands-On Microservices with JavaScript:Build scalable web applications with JavaScript, Node.js, and Docker[M].Packt Publishing Limited:2024-12-20.DOI:10.0000/9781788625265.
- Bethany G ,Manuel S .Node.js Cookbook:Practical recipes for building server-side web applications with Node.js 22[M].Packt Publishing Limited:2024-11-15.DOI:10.0000/9781804614105.
- 黎青霞.Node. js在Web开发中的应用研究[J].信息记录材料,2024,25(10):91-93+96.DOI:10.16009/j.cnki.cn13-1295/tq.2024.10.074.
- Sravani C ,Kumar P ,Priya S , et al.Constructing a Study Buddy Using MERN (MongoDB, Express.js, React, Node.js) Stack Technologies †[J].Engineering Proceedings,2024,66(1):27-27.
- 李淑玲,朱彤.基于Node.js技术的在线测试系统设计方案[J].科技资讯,2023,21(19):35-38.DOI:10.16661/j.cnki.1672-3791.2303-5042-5997.
- 冯越.基于交互设计的手绘动画游戏在点单小程序中应用的探索[J].美术教育研究,2023,(13):121-123.
- 曾娟,陈莹燕.个性化消费背景下低度酒点单小程序设计研究[J].科技创新与生产力,2022,(11):100-102.
- 吴婷婷,孟思明.MySQL数据库[M].人民邮电出版社:202207.271.
- 王卉.彭庆福餐厅点单系统的设计与实现[D].南京大学,2020.DOI:10.27235/d.cnki.gnjiu.2020.001531.
致谢
在此论文完成之际,感谢我的指导老师。在指导老师的网页设计课上,当时我学到了很多东西,这对于我实习过程中也打了一定的基础,而且指导老师对于我的设计也提出许多建议,并予以悉心的指导,对于一些细小的问题都耐心的指导我去完善,授予我写论文的交流消息,时常的鼓励我,另外感谢教导我完善此项目的前端同学,对于这个项目,我是边学习边实现完成的,有许多东西开始并不是很明白,但前端开发的同学非常耐心的引导我去将这个项目完成,在系统的后端开发中,所用到的后台开发技术也时常会给我讲解,助于我更好的将论文完成,在此对帮助到我的同学和一直予以教导的指导老师致以衷心的感谢,祝事业有成。
1044

被折叠的 条评论
为什么被折叠?



