《《.Net开发技术基础》课程设计报告商店客户管理系统.doc》由会员分享,可在线阅读,更多相关《《.Net开发技术基础》课程设计报告商店客户管理系统.doc(49页珍藏版)》请在三一办公上搜索。
1、摘要随着高科技的迅猛发展,信息技术己经深入生活中的各个领域。商店客户管理系统是典型的信息系统,本次课程设计主要包括后台数据库的建立、程序代码的实现和软件测试,要求建立起数据一致性,并建立了触发器、视图、存储过程等。本系统是源于重庆科技学院校园超市的客户管理系统,收银员可以利用员工号进入收银系统,管理员可以利用本系统对客户的信息进行管理,同时对客户购买的历史记录进行查询,客户可以在本系统给管理员留言。系统简单易懂,能够适应大多数能源公司的要求。关键词:信息技术 客户管理系统 软件测试重庆科技学院课程设计任务书设计题目:商店客户管理系统学生姓名课程名称.NET开发技术基础课程设计专业班级地 点起止
2、时间2012 年6月 18 日至 202 年 6 月 22日设计内容及要求1、设计内容 : 重庆科技学院校园超市为了更好的管理学校超市的客户(学生、或教师),决定开发一套校园超市客户管理系统。该系统要求有以下功能: 1、客户基本信息录入(姓名,学号或工号,性别,班级或是部门,客户号) 2、商品信息录入、修改。等。 3、客户购买商品信息登记(要求能记录住每一个客户何时、购买了何产品,价格是多少) 4、客户级别管理(当客户在商店累记消费达到一定数量时,可以升为一级会员、二级会员、三级会员、等等,以后不同级别会员购买商品时,客户可以享有不同的折扣或是优惠) 5、查询管理(注册客户信息查询、客户购买产
3、品记录查询,产品数量查询等)2、要求:代码实现要体现OOA程序设计的思想代码实现需采用C#语言代码要能调试通过并运行,体现优化的思想进行创新设计3、技术要求:该系统要求采用C/S模式或是B/S模式实现,但从技术上,必须达到以下要求。1、 安装包(必有10分)2、 运行不出错,要进行错误捕获处理机制(必有15分)3、 数据库连结不出错,写出,读出(必有15分)4、 菜单、下拉框、状态栏(选有10分)5、 水晶报表(必有15分)6、 帮助(必有15分)7、 美工(选有15分)8、 .dll(选有15分)9、 WebService(选有15分)10、 调用了数据库中的视图(10分)、调用了数据库中的
4、存储过程(10分)。(必有)注:必有的技术,必须在实现,选有项,则根据自身要求,和软件项目的要求,自己选用,如果采用除以上技术以外的其它技术,答辨时,请特别提出。 4.数据库设计要求(必须达到以下要求): 1、数据库用的表不少于5个(20分) 2、表与表之间必须有引用,必有参照完整性约束(20分) 3、数据库中的视图必须不少于5个(20分) 4、数据库中的存储过程不少于5个(20分) 5、数据库在的触发器不少于2个(20分)设计参数进度要求第一阶段:分析系统中需要实现的功能; 第二阶段:根据问题描述,设计系统的解决方案; 第三阶段:完成各个功能模块的划分,及其代码编写;第四阶段:测试并完成报告
5、、答辩参考资料1、Mickey Williams Visual c#.NET技术内幕(第二版)清华大学出版社2007.32、王辉、张大治Visual c#程序设计实用教程(第一版)清华大学出版社2007.3 3、刘烨、吴中元C#编程及应用程序开发教程(第一版) 清华大学出版社2006.5其它考核方法:课程设计报告 20%代码 60%答辩 20%评定方式:总分:100分1、0- 59分:不及格;2、60- 69分:及格;3、70- 79分:中;4、80- 89分:良;5、90-100分:优5、90-100分:优秀说明.本表应在每次实施前一周由负责教师填写二份,院系审批后交院系办备案,一份由负责教
6、师留用。.若填写内容较多可另纸附后。3.一题多名学生共用的,在设计内容、参数、要求等方面应有所区别。教研室主任: 指导教师: 年 月 日 目 录1 设计要求和内容11.1 设计背景11.2 开发环境11.3 系统内容及要求11.3.1系统目标设计11.3.2 系统功能要求12.2 需求分析221 需求分析22.1.1 系统管理员对功能的需求22.1.2 管理员对功能的需求22.1.3 员工对功能的需求22.2 系统功能描述32.2.1 登陆32.2.2 管理员信箱管理32.2.3 客户信息管理32.2.4 员工信息管理32.2.5 管理员账号管理32.2.6商品信息管理43 数据库分析和设计4
7、3.1 E-R实体图43.1.1 管理员实体图43.1.2 员工实体图43.1.3 客户实体图53.1.4 商品实体图53.1.5 购买信息实体图53.1.6 折扣实体图63.2 数据表的建立63.2.1员工信息表63.2.2 客户信息表63.2.3 商品信息表73.2.4 购买信息表73.2.5 折扣信息表84 功能模块的具体设计与实现94.1 客户信息管理:94.2 员工信息管理104.3 管理员账号管理114.4 商品信息管理125 软件测试1351 系统测试1352 测试用例136 致谢167 参考文献171 设计要求和内容1.1 设计背景重庆科技学院校园超市为了更好的管理学校超市的客
8、户(学生、或教师),实现客户管理的系统化、规范化和自动化,同时为了尽量减少手工操作,使商店管理更加现代化,决定开发一套校园超市客户管理系统。1.2 开发环境本商店客户管理系统的开发与运行环境如下:开发环境:Visual Studio 2005辅助工具:PowerDesigner Trial 11数据库管理系统:SQL Server 2000运行环境:Windows 2000/XP/20031.3 系统内容及要求1.3.1系统目标设计1)实现商店客户管理的系统化、规范化和自动化;2)尽量减少手工操作,使商店管理更加现代化。1.3.2 系统功能要求1、客户基本信息录入(姓名,学号或工号,性别,班级
9、或是部门,客户号) 2、商品信息录入、修改。等。 3、客户购买商品信息登记(要求能记录住每一个客户何时、购买了何产品,价格是多少) 4、客户级别管理(当客户在商店累记消费达到一定数量时,可以升为一级会员、二级会员、三级会员、等等,以后不同级别会员购买商品时,客户可以享有不同的折扣或是优惠) 5、查询管理(注册客户信息查询、客户购买产品记录查询,产品数量查询等)2.2 需求分析商店客户管理系统是根据商店日常办公的需要来设计开发的案例,目标是提高商店客户管理的工作效率,实现商店客户管理的系统化、规范化和自动化,具有对客户信息、客户会员等级系统、管理员信息、员工信息、客户购买商品信息、客户留言信息进
10、行管理和维护的功能。系统主要包括系统管理员对功能的需求、管理员对功能的需求和员工对功能的需求。21 需求分析2.1.1 系统管理员对功能的需求 增加管理员的账号密码。2.1.2 管理员对功能的需求 客户基本信息管理:可添加、修改和删除客户的信息; 客户购买商品信息管理:可添加、修改商品信息; 客户级别管理:当客户在商店累记消费达到一定数量时,可以升为一级会员、二级会员、三级会员,以后不同级别会员购买商品时,客户可以享有不同的折扣或是优惠; 查询管理:客户信息查询、客户购买记录查询、商品信息及数量查询、员工基本信息查询; 密码修改:修改本人的密码2.1.3 员工对功能的需求 客户基本信息管理:可
11、添加、修改和删除客户的信息; 密码修改:修改本人的密码; 收银管理:可以对客户购买商品进行管理。2.2 系统功能描述系统的功能包括:登陆、管理员信箱管理、客户信息管理、员工信息管理、管理员账号管理、商品信息管理、收银管理、历史记录管理、客户等级管理。2.2.1 登陆由于本系统涉及不同的用户,因此需要对不同用户分配不同的登陆首页,并记录下是何种类型的用户登陆。2.2.2 管理员信箱管理 客户可以在点击登陆界面下的管理员信箱按钮进入管理员信箱,并根据要求给管理员留言;管理员登陆后,可以在查看信箱选项下查看所有的留言。2.2.3 客户信息管理管理员和员工都拥有对客户信息进行操作的功能,分别登陆各自首
12、页后,可以对客户信息进行查看、增加、删除和修改。2.2.4 员工信息管理管理员在登陆进首页后,可以对客户信息进行查看、修改、密码初始化等功能,而员工在登陆之后可以对自己的密码进行修改。2.2.5 管理员账号管理管理员在登陆之后可以对自己的密码进行修改;系统管理员则拥有增加管理员的功能。2.2.6商品信息管理管理员在登陆之后,可以对商店的商品信息进行查看以及修改。3 数据库分析和设计3.1 E-R实体图3.1.1 管理员实体图管理员实体具有账号和密码两个属性,E-R图如图3.1所示:管理员账号密码图3.1 管理员实体图3.1.2 员工实体图员工实体具有员工号、员工姓名、性别、联系方式和密码五个属
13、性,E-R图如图3.2所示:性别管理员员工号员工姓名联系方式密码图3.2 员工实体图3.1.3 客户实体图客户具有客户号、客户姓名、学号(或工号)、性别、部门(或班级)、客户等级、联系方式七个属性,E-R图如图3.3所示:管理员客户号客户姓名联系方式部门(或班级)性别客户等级学号(或工号)图3.3 客户实体图3.1.4 商品实体图商品具有商品号、商品名、价格、供应商、进价、剩余数量六个属性,E-R图如图3.4所示:价格管理员商品号商品名供应商进价剩余数量图3.4 商品实体图3.1.5 购买信息实体图购买信息具有流水号、客户号、商品号、经办人、购买日期、购买数量、购买价格七个属性,E-R图如图3
14、.5所示:商品号管理员流水号客户号经办人购买日期价格购买数量图3.5 购买信息实体图3.1.6 折扣实体图折扣具有客户等级、等级折扣、所需购买价格三个属性,E-R图如图3.6所示管理员客户等级购买所需价格等级折扣图3.6 折扣实体图3.2 数据表的建立3.2.1员工信息表员工信息表用来存放商店客户管理系统中员工登陆的账号、密码以及一些基本信息,表中的各个字段的数据类型、大小如表3.1所示:表3.1员工信息表NameCodeData TypeLength备注员工号SNoVA1515姓名SNameVA3030性别SsexA22联系方式StelVA1515密码SPassWordVA15153.2.2
15、 客户信息表客户信息表用来存放注册客户的基本信息,表中的各个字段的数据类型、大小如表3.2所示:表3.2 客户信息表NameCodeData TypeLength备注客户号CNoVA1515姓名CSnameVA3030学号或工号CSNoVA1515性别CSSexA22班级或部门CSClassVA3030会员等级CSLevelI联系方式StelVA15153.2.3 商品信息表商品信息表用来存放商店商品的基本信息,表中的各个字段的数据类型、大小如表3.3所示:表3.3品信息表NameCodeData TypeLength备注商品代号GNoVA1515商品名称GNameVA3030商品单价GPri
16、ceMN进价GJPriceMN商品供应商名称GgongyingVA3030剩余数量GAmountI3.2.4 购买信息表购买信息表用来存放客户购买的基本信息,表中的各个字段的数据类型、大小如表3.4所示:表3.4 购买信息表NameCodeData TypeLength备注流水号BNoVA1515商品代号GNoVA1515客户号CNoVA1515员工号SNoVA1515购买数量GBuyAmountI购买价格GBuyPriceMN购买时间BtimeDT3.2.5 折扣信息表折扣信息表用来存放折扣的基本信息,表中的各个字段的数据类型、大小如表3.6所示:图3.6 折扣信息表NameCodeData
17、 TypeLength备注会员等级CSLevelI折扣ZhekouF所需消费XiaofeiMN4 功能模块的具体设计与实现4.1 客户信息管理:客户信息管理的具体功能如下:员工和管理员都可对客户进行操作,包括增加、删除和修改功能,具体实现代码如下:1)查看客户信息主要代码(学号查询):Class1 ss = new Class1(); string strSql = select CNo as 客户号,CSname as 姓名,CSNo as 学号或工号,CSSex as 性别,CSClass as 班级或部门,CSLevel as 会员等级,CSTel as 联系方式from Custome
18、rs where CSNo = 0; strSql = string.Format(strSql, textBox1.Text.Trim(); DataSet ds = ss.GetData(strLianjie, strSql); dataGridView1.DataSource = ds; dataGridView1.DataMember = ds.Tables0.ToString(); if (ds.Tables0.Rows.Count = 1) for (int i = 0; i 0) MessageBox.Show(已存在此管理员); textBox1.Text = ; return
19、; string strSql1 = insert into admin values(0,123456); strSql1 = string.Format(strSql1, textBox1.Text.Trim(); ss.UpdateData(strLianjie, strSql1); MessageBox.Show(增加成功);2)初始化员工信息主要代码Class1 ss = new Class1(); string strSql = select * from admin where ANo = 0; strSql = string.Format(strSql, textBox1.Te
20、xt.Trim(); DataSet ds = ss.GetData(strLianjie, strSql); if (ds.Tables0.Rows.Count = 0) MessageBox.Show(该管理员不存在); textBox1.Text = ; return; string strSql1 = update admin set APassWord = 123456 where ANo = 0; strSql1 = string.Format(strSql1, textBox1.Text.Trim(); ss.UpdateData(strLianjie, strSql1); Me
21、ssageBox.Show(初始化成功);4.4 商品信息管理商品信息管理的具体功能如下:管理员可以对商品的基本信息进行增加和修改,具体实现代码如下:1)查看商品信息主要代码(商品号查询):Class1 ss = new Class1(); string strSql = select GNo as 商品代号,GName as 商品名,GPrice as 价格,GJPrice as 进价,Ggongying as 供应商,GAmount as 剩余数量from Goods where GNo = 0; strSql = string.Format(strSql, textBox1.Text.T
22、rim(); DataSet ds = ss.GetData(strLianjie, strSql); dataGridView1.DataSource = ds; dataGridView1.DataMember = ds.Tables0.ToString(); if (ds.Tables0.Rows.Count = 1) for (int i = 0; i ds.Tables0.Rows.Count; i+) comboBox2.Items.Add(ds.Tables0.Rowsi商品代号.ToString(); 2)商品信息修改主要代码:Class1 ss = new Class1();
23、 string strSql = update Goods set GPrice= 0,GJPrice = 1,Ggongying = 2,GAmount = 3where GNo = 4; strSql = string.Format(strSql,textBox5.Text.Trim(),textBox6.Text.Trim(),textBox4.Text.Trim(),textBox7.Text.Trim(),textBox2.Text.Trim(); ss.UpdateData(strLianjie, strSql); MessageBox.Show(修改成功);5 软件测试51 系统
24、测试为了总结系统中遇到的问题,描述系统是否符合需求,特进行本次需求分析。由于条件限制,测试人员即为开发人员。软件测试主要由单元测试、综合测试和确认测试三部分组成。综合测试:主要测试软件结构问题,因测试建立在各功能模块的接口上,使用黑盒测试法,以便对主要的功能路径进行测试,验收测试根据需求分析时确立的标准检验软件是否满足功能要求、行为和性能方面的要求,这步完全采用黑盒法,整个系统确认后,将与系统其他所有部分集成后进行系统测试检验系统的协调性及功能和性能是否达到要求。单元测试:本次测试所采用的是白盒测试法,检查模块控制结构的某些特殊路径,期望覆盖尽可能多的出错点;经过单元侧试后的模块,组装为软件包
25、,对软件包进行综合测试。确认测试:根据需求分析时确定的验收标准检验软件是否满足功能、行为和性能方面的要求,这一步完全采用黑盒法。52 测试用例图5.1 客户信息管理测试图5.2 增加客户测试图5.3 商品信息管理测试图5.4 增加商品测试图5.5 增加员工测试图5.6 员工信息管理测试6 致谢在一周的课程设计里,感谢裴老师的悉心指导,感谢各位帮助过我的同学们。7 参考文献1、Mickey Williams Visual c#.NET技术内幕(第二版)清华大学出版社2007.32、王辉、张大治Visual c#程序设计实用教程(第一版)清华大学出版社2007.3 3、刘烨、吴中元C#编程及应用程
26、序开发教程(第一版) 清华大学出版社2006.5登录窗体代码:using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using TheSqlLibrary;namespace Supermarket public partial class Form1 : Form private string _u
27、serName; private string _uid; public string UserName get return _userName; public string UID get return _uid; public Form1() InitializeComponent(); private void OK_Click(object sender, EventArgs e) if (Check() DialogResult = DialogResult.OK; else MessageBox.Show(输入有误,请重新输入!); textName.Text = ; textN
28、um.Text = ; textPWD.Text = ; textName.Focus(); bool Check() string str = select * from EmployeeTable where EName=0 and EUID=1 and EPWD=2; str = string.Format(str, textName.Text, textNum.Text, textPWD.Text); DataSet ds = Myku.getDataSet(str); if (ds.Tables0.Rows.Count = 1) _userName = this.textName.Text; _uid = ds.Tables0.Rows00.ToString(); return true; return false; private void Cancel_Click(object sender, EventArgs e) DialogResult = DialogResult.Cancel; this.Close(); private void label5_Click(object sender, EventArgs e) Form9 frm9 = new Form9(); frm9.