欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    精品word超市会员管理系统详细代码.docx

    • 资源ID:15077709       资源大小:346.19KB        全文页数:23页
    • 资源格式: DOCX        下载积分:5金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要5金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    精品word超市会员管理系统详细代码.docx

    1、精品word超市会员管理系统详细代码数据库设计1 系统数据库分析数据库设计是建立数据库及其应用系统的技术,是系统开发和建设中的核心技术。具体说,数据库设计是指对于一个给定的应用环境,构造最优的数据库模式,建立数据库及其应用系统,使之能够有效的存储数据,满足各种用户的应用需求(信息要求和处理要求)。数据库结构设计的好坏直接对应用系统的效率以及实现的效果产生影响。根据超市会员管理系统功能设计的需要,数据库结构设计如下所示:(1). 用户登录信息数据表(Login):(用户账号,密码,登录身份);(2). 会员基本信息数据表(Member):(用户账号,用户姓名,身份证号,联系方式,联系地址);(3

    2、). 职员基本信息数据表(Employee):(职员号,职员姓名,职员职位);(4). 会员积分信息数据表(Score):(会员账号,会员积分,会员等级,会员折扣);2 数据库概念结构设计根据上节的数据项和数据结构以后,就可以设计出能够满足用户需求的各种实体,以及它们之间的关系,为以后的逻辑结构设计打下基础,这些实体包括各种具体信息,通过相互之间的作用形成数据的流动。各种实体具体的描述E-R图如下。1. 用户登录信息实体图主要描述了登录用户的基本情况,包括了用户的用户账号,密码,登录身份。如图3-11所示,用户登录信息实体E-R图。图3-12 用户登录实体的E-R图2. 会员基本信息实体图主要

    3、描述会员的基本情况,包括了会员基本信息的用户账号,用户姓名,身份证号,联系方式,联系地址,得出如图3-12所示会员基本信息实体E-R图。图3-13 会员基本信息实体的E-R图3. 职员基本信息实体图主要描述新生的基本情况,包括了职员基本信息的职员号,职员姓名,职员职位,得出如图3-13所示职员基本信息实体E-R图。图3-14 职员基本信息实体的E-R图4. 会员积分信息实体图主要描述会员积分的基本情况,包括了会员积分基本信息的会员账号,会员积分,会员等级,会员折扣,得出如图3-14所示会员积分信息实体E-R图。图3-15 会员积分信息实体的E-R图实体之间的关系E-R图主要描述实体间的关系。图

    4、3-16 各实体之间的关系3.系统数据库的设计根据需求分析与概念结构设计,建立数据库系统支持的数据模型,即数据库的逻辑结构。本系统利用Microsoft Access 2003创建了名为SuperMarket的数据库。本系统主要建立了以下四张表:表3.1 用户登录数据表字段名数据类型字段大小是否主键DNO(登陆账号)文本6是DCode(密码)文本12否DUserSta(登录身份)文本50否表3.2 会员基本信息数据表字段名数据类型字段大小是否主键MNO(用户账号)文本6是MName(用户姓名)文本20否MID(身份证号)文本18否MTel(联系电话)文本50否MAdd(联系地址)文本50否表3

    5、.3 职员基本信息数据表字段名数据类型字段大小是否主键EID(职员号)文本6是EName(职员姓名)文本20否EStatus(职员职位)文本50否表3.4 会员积分信息数据表字段名数据类型字段大小是否主键MNO(会员账号)文本6是MScore(用户积分)数字(double)否MGrade(用户等级)数字(long)否MDiscount(用户折扣)数字(double)否4. 表之间的关系表之间存在的关系如下:1在会员基本信息表(Member)中添加信息的同时,把信息添加到用户登录信息表(Login)中,同时将信息添加到积分信息表(Score)中。2在会员基本信息表(Member)中删除会员信息的

    6、同时,把用户登录信息表(Login)和用户积分信息(Score)中该会员信息删除。3在职员基本信息表(Member)中添加信息的同时,将志愿的基本信息添加到用户登录信息表(Login)中。4在职员基本信息表(Member)中删除职员信息的同时,把用户登录信息表(Login)中该职员信息删除。详细设计与实现1. 系统首页图4-1 超市会员管理系统首页自定义工具栏按钮及鼠标提示信息的设计与实现:图4-2 主页面工具栏在对话框的OnInitDialog方法中常见工具栏窗口和图像列表窗口,关联图像列表,设置工具栏按钮文本,启动工具栏的EnableToolTip方法激活提示功能。鼠标提示信息的实现,处理

    7、TTN_NEEDTEXT消息的响应函数OnToolTipText(),通过函数的参数获得工具栏按钮的ID,从而根据ID获取提示信息文本。1.添加消息映射(最好写在AFX_MSG_MAP宏外,否则可能出现编译错误)ON_NOTIFY_EX_RANGE(TTN_NEEDTEXTW,0,0xFFFF,OnToolTipText)ON_NOTIFY_EX_RANGE(TTN_NEEDTEXTA,0,0xFFFF,OnToolTipText)2.添加事件声明(最好写在AFX_MSG宏外,否则可能出现编译错误)afx_msg BOOL OnToolTipText(UINT nID, NMHDR* pNMH

    8、DR, LRESULT* pResult);2 登录页面系统运行后,首先展现给用户的是用户登录界面,用户登录成功后进入到主页面,用户登录界面如下图所示:图4-3 用户登录界面用户登录有三种身份,管理员、普通职员、会员。管理员登录成功后,可以对系统各模块进行操作;普通职员登录成功后,除对职员的添加、删除外,均可实现操作;会员,则只能对自己的一些基本信息进行操作。登录界面由函数void CLoginDlg:OnOK()实现处理,具体代码如下:/实现该功能的SQL语句sql=select * from Login where DNO=+Name+ and DCode=+ECode+ and DUse

    9、rSta=+EStatus+; m_pRs-Open(_bstr_t)sql,theApp.conn.GetInterfacePtr(),adOpenKeyset,adLockOptimistic,adCmdText);/登录成功与否、登录次数判断if ( m_pRs-GetRecordCount()=0 )if ( m_LoginNumadoEOF)CString temp;m_EList.InsertItem(1000,);for(int i=0;iGetFields()-GetItem(long)i)-Value;m_EList.SetItemText(row,i,temp);m_pRs

    10、-MoveNext();row+=1;4.3.2 会员密码修改此模块用于修改会员的登录密码。图4-5 会员密码修改界面填入用户账号和旧密码后,系统检查数据库中是否有该记录,如果存在该记录,则可填写新密码进行修改;若不存在,则系统给出提示信息。如下图:图4-6 会员密码修改提示信息界面该模块单击事件由函数void CECodeModifyDlg:OnOK()实现,具体代码如下:sql=Update Login set DCode=+NewCode+ where DNO=+Name+;trytheApp.conn-Execute(_bstr_t)sql,NULL,adCmdText);catch(

    11、_com_error &e)AfxMessageBox(e.Description();AfxMessageBox(修改成功);4. 积分信息模块(1) 积分查询该功能实现界面如下:图4-7 积分查询界面输入会员账号后,点击确定按钮,系统首先检查账号是否存在,若存在则输出该会员积分信息;若不存在,输出提示信息。实现原理如会员信息模块中的会员查询。实现函数为:void CJQueryDlg:OnOK()。在编辑框中的显示实现为:var = m_pRs-GetCollect(MScore);if(var.vt != VT_NULL)str1 = (LPCSTR)_bstr_t(var);GetDl

    12、gItem(IDC_EDIT_Jifen)-SetWindowText(str1); var = m_pRs-GetCollect(MGrade);if(var.vt !=VT_NULL)str2=(LPCSTR)_bstr_t(var);GetDlgItem(IDC_EDIT_Grade)-SetWindowText(str2);var = m_pRs-GetCollect(MDiscount);if(var.vt !=VT_NULL)str3=(LPCSTR)_bstr_t(var);GetDlgItem(IDC_EDIT_Discout)-SetWindowText(str3);(2)

    13、积分兑换积分兑换功能的实现界面如下:图4-8 积分兑换功能实现界面用户输入账号和密码后,点击兑换按钮,该按钮的实现中,首先检查用户合法性。若用户已兑换过积分,则提示及兑换;若积分不够兑换等级,则提示积分不够;若兑换成功后,则显示用户等级和优惠折扣。该模块实现单击事件函数处理为:void CEXchangeDlg:OnOK(),具体实现如下:/修改数据库中积分sql=Update Score set MGrade=1,MDiscount=0.1 where MNO=+mzh+;trytheApp.conn-Execute(_bstr_t)sql,NULL,adCmdText);catch(_co

    14、m_error &e)AfxMessageBox(e.Description();AfxMessageBox(兑换成功);(3) 消费加分该模块功能将会员的消费金额换为消费积分,如下图:图4-9 消费加分模块界面实现图输入用户账号和消费金额后,首先检查数据库中是否存在该记录,如果存在,则将该用户积分增加其消费金额数目,如不存在,系统弹出提示信息。模块单击事件处理由函数void CXiaoFeiDlg:OnOK()实现,具体代码如下:sql=Update Score set MScore=MScore+JiE+ where MNO=+UserZH+;trytheApp.conn-Execute(

    15、_bstr_t)sql,NULL,adCmdText);catch(_com_error &e)AfxMessageBox(e.Description();AfxMessageBox(添加成功);(4) 优惠讯息该模块为静态功能。点击优惠讯息菜单即出现超市积分的优惠政策及兑换政策的对话框。5 基本信息管理模块1) .职员信息管理(1). 查询基本信息 该模块功能实现基本与会员基本信息查询相同,在此不再赘述。实现该功能的函数为:void CEmployeeDlg:OnOK();实现该功能的SQL语句为:sql=select * from Employee where EID=+EmpID+;(2

    16、). 修改职员信息该模块功能修改超市职员的基本信息。函数实现:void CMIMDlg:OnOK()。其实现如下:GetDlgItem(IDC_EDIT1_EmpName)-GetWindowText(EXm);GetDlgItem(IDC_COMBO_EmpSta)-GetWindowText(EZw);if(EZw=管理员) EZw=0;else if(EZw=普通职员) EZw=1;sql=Update Employee set EName=+EXm+,EStatus=+EZw+ where EID=+EMId+;trytheApp.conn-Execute(_bstr_t)sql,NU

    17、LL,adCmdText);catch(_com_error &e)AfxMessageBox(e.Description();AfxMessageBox(修改成功);(3). 修改密码职员修改密码模块与会员密码修改类似,实现函数为:void CMModifyDlg:OnOK(),此处不再赘述。具体SQL语句实现为:sql=Update Login set DCode=+NewCode+ where DNO=+Name+;trytheApp.conn-Execute(_bstr_t)sql,NULL,adCmdText); catch(_com_error &e)AfxMessageBox(e

    18、.Description();(4). 添加职员信息管理员进入系统后可以按照需求添加职员信息,该模块首先检验输入是否为空,若不为空,则可以进行添加,此功能同时将信息添加到Login表和Employee表中,界面实现如图:图4-10 添加职工信息实现该事件的函数为:void CEAddEmplyeeDlg:OnOK(),下面是添加职员信息的具体实现: sql=Insert into Employee(EID,EName,EStatus) values(+Eno+,+Ename+,+Esta+);SQL=Insert into Login(DNO,DCode,DUserSta) values(+E

    19、no+,+Ecode+,+Esta+);trytheApp.conn-Execute(_bstr_t)sql,NULL,adCmdText);theApp.conn-Execute(_bstr_t)SQL,NULL,adCmdText);catch(_com_error &e)AfxMessageBox(e.Description();AfxMessageBox(添加成功); (5). 删除职员信息该模块只能由管理员进行操作,管理员成功登录后,可以按照职员号删除职员信息,如图所示:图4-11 删除职工信息图在删除前,系统会给出提示,提醒用户是否确定要删除。点击是,则将该记录从数据库中删除;点击

    20、否,则撤销删除行为。实现函数为void CDelEmpDlg:OnOK(),代码如下:if(MessageBox(确定要删除该记录吗?,提示,MB_YESNO)=IDYES)sql=delete from Employee where EID=+EmpNO+;SQL=delete from Login where DNO=+EmpNO+;trytheApp.conn-Execute(_bstr_t)sql,NULL,adCmdText);theApp.conn-Execute(_bstr_t)SQL,NULL,adCmdText);catch(_com_error &e)AfxMessageB

    21、ox(e.Description();AfxMessageBox(删除成功);2 会员信息管理会员信息管理包括会员信息查询、会员信息修改、会员注册、会员删除四个模块,功能实现同职员信息管理模块中响应功能。实现函数分别为:void CMemberDlg:OnOK()、void CModifyMemDlg:OnBUTTONModify()、void CMemAddDlg:OnOK()、void CModifyMemDlg:OnBUTTONDel()。此处以会员信息修改和删除为例,其他功能实现略写。图4-12 会员信息修改图中,灰色编辑框表示不可改。如果要修改信息则填入要修改的值,点击“确定修改”,

    22、即可修改成功;如果要删除该条记录,则点击“确定删除”,系统会提示,是否真的删除,若是,则从数据库表中将该记录删除,若否,则退出删除。此处实现的相关的SQL语句为:/修改sql=Update Member set MName=+UserName+,MTel=+UserTel+,MAdd=+UserAdd+ where MNO=+UserNO+;trytheApp.conn-Execute(_bstr_t)sql,NULL,adCmdText);catch(_com_error &e)AfxMessageBox(e.Description();AfxMessageBox(修改成功);/删除if(M

    23、essageBox(确定要删除该记录吗?,提示,MB_YESNO)=IDYES)sql=delete from Member where MNO=+UserNO+;SQL=delete from Login where DNO=+UserNO+;trytheApp.conn-Execute(_bstr_t)sql,NULL,adCmdText);theApp.conn-Execute(_bstr_t)SQL,NULL,adCmdText);catch(_com_error &e)AfxMessageBox(e.Description();AfxMessageBox(删除成功);6 统计统计模块

    24、是对超市会员积分进行统计,可以统计出各登记人数及所占百分比,并以柱形图的形式显示出来。图4-13 统计分析功能实现图实现该功能的函数为:void CStatDlg:OnOK()具体实现:(1) 打开记录集,获得各等级人数;(2) 绘制柱形图/获取静态图片空间大小CWnd * pWnd=this-GetDlgItem(IDC_DRAW); pWnd-GetClientRect(&rectPic);/ 获取设备环境指针CDC *pDC=pWnd-GetDC();/ 重新填充静态图片区域CBrush NewBrush;NewBrush.CreateSolidBrush(RGB(238,238,237

    25、);CBrush * pOldBrush=pDC-SelectObject(&NewBrush);pDC-Rectangle(&rectPic);pDC-SelectObject(pOldBrush);/ 确定每个柱形条的宽度int nLength=(rectPic.right-rectPic.left)/6;/ 定义五种颜色,用来填充柱形图COLORREF RGBArray6=RGB(0,255,0),RGB(128,0,255),RGB(0,0,255), RGB(255,255,0), RGB(255,0,0),RGB(0,128,255);/ 定义一个矩形,表示柱形条CRect rec

    26、t;for ( int i=0; iSelectObject(&NewBrush);pDC-Rectangle(&rect);pDC-SelectObject(pOldBrush);/ 释放设备环境this-ReleaseDC(pDC);7 系统信息1 用户帮助系统调用帮助文件Market-Help.chm,对于不熟悉本系统的用户可以通过阅读帮助文件了解系统如何使用。点击用户帮助菜单或帮助工具栏按钮后,即打开帮助文件,如图所示:图4-14 用户帮助功能实现图具体实现为:void CCMarketDlg:OnMENUHelp() char bufMAX_PATH;:GetCurrentDirectory(MAX_PATH,buf); /获取程序根目录路径:ShellExecute(NULL, open, Market-Help.chm, , , SW_SHOW);2 关于本系统具体实现:void CCMarketDlg:OnMENUAbout() CDialog about(ID


    注意事项

    本文(精品word超市会员管理系统详细代码.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开