商场购物管理系统(共19页).doc
精选优质文档-倾情为你奉上 PINGDINGSHAN UNIVERSITY RFID原理与应用课程设计题 目: 商场购物管理系统的实现 院(系): 信息工程学院 专业年级: 物联网工程专业 2014 姓 名: ghhkkjklk 学 号: uhhkjjjk 指导教师: ghkkjjkj 2016年6月25日 专心-专注-专业目 录1 绪论该部分主要介绍当前商场购物管理系统的背景及意义。基于数据库的商场购物管理系统能够使商场商品信息透明化,同时提高商场员工的工作效率。1.1 课题的背景及意义 不管何时,人们总是喜欢逛商场超市,为了让商场的工作人员能够更加便捷的工作,我们设计了这个商场购物管理系统,能够轻松地查看商品的信息以及完成顾客所买商品的结算功能。商场购物管理系统是一个功能强大,且具有很强的时效性、可靠性,可方便处理业务。本系统应达到以下目标:(1) 系统采用人机交互的方式,界面美观友好,信息查询灵活、方便,数据存储安全可靠。(2) 能够准确、详细查询当前可供查询商品的信息。(3) 能够提供购买商品的功能。(4) 能够添加删除管理员。1.1.1 系统功能设计(1) 系统选择主要是可选购买登录系统或管理员登录系统。(2) 用户登录是登录进入管理员身份。(3) 商品管理是对超市的所有商品信息进行统计,包括数量单价等。(4) 商品详情是查看统计顾客所要购买的商品的信息。(5) 付款界面是顾客付钱是所支付的钱。图1.总体模块设计图1.1.2 系统设计商场购物管理系统将所需功能整合在一起统一处理,方便了管理者的多种处理,节约时间、精力。本系统采用C#编程语言,该语言是面向对象的编程语言,模块化处理,扩展性强,便于数据管理,同时也具有较高的安全性,易用性。本系统采用.net framework 框架结构,管理员登录后就可以对相关数据的操作,使用方便、简单,顾客可以直观的看到自己所买物品的信息并可以对不正确的信息提出申请修改。本系统采用SQL Sever语言进行数据库的连接,同时可对数据库信息进行备份、恢复及清空数据库操作。数据库是商场购物管理系统的后台,存储着所有的信息,在商场购物管理系统中有着很重要的地位。数据库设计的好与坏,直接影响到这个系统的运行效率。良好的数据库设计,可以提高数据信息的存储效率,确保数据信息的完整性和一致性。1.2 论文主要工作和结构安排该论文主要工作是在.NET操作系统下,利用c#开发语言,借助数据库SQL Sever来实现一个商场购物管理系统。其目标在于实现超市对库存商品的信息的清点以及对顾客购物的结算。结构安排上,该论文主要分为绪论、系统功能、相关技术及工具介绍、总结四个部分,每一个部分具体分工如下:1、 绪论:该部分主要介绍当前文件管理系统的背景及意义,以及论文主要工作及结构安排。基于c#的商场购物管理系统能够安全方便地库存商品的整体动态信息,从而降低工作量。2、系统功能:该部分主要介绍该系统功能设计以及系统功能分析,从而能够展示整个系统的功能的规划。3、相关技术及工具介绍:该部分主要介绍系统所采用的技术及开发工具,涉及该系统采用的开发工具及技术,以及该系统涉及的数据库相关知识。4.总结:该部分主要介绍在整个管理系统实现过程中所遇到的细节性问题以及对今后的展望。2 系统功能该部分主要介绍该系统功能设计以及系统功能分析,从而能够展示整个系统的功能的规划。2.1 系统功能设计根据需求分析确定该系统划分为以下几个管理功能:(1)系统选择该界面用于选择进入哪种系统:购买系统或管理员系统,点击相应的按钮则会进入对应的系统。图2.系统选择界面图(2) 用户登录 点击管理员登录则进入该进入界面,输入账号密码进行用户登录,并且用户名和密码的信息是建立在数据库中的,如需添加管理员,直接添加在数据库中即可。图3.用户登录界面图表1.管理员信息表(3)商品管理该界面用于查看添加入库商品的信息以及库存商品的信息,并对库存商品的信息进行修改和查询。 在“添加”界面中按要求填入商品的名称、单价、数量,点击添加按钮即可。在“修改删除”界面中,点击“查询”按钮即可看到所有商品的详细信息,若输入某商品名称仅查看到该商品的信息;点击到商品信息的某一栏,更改数字,点击“修改按钮”则商品的这一信息就被修改成功。图4.添加商品信息界面图5.商品信息修改删除界面(4) 商品详情 点击“购买系统”则进入商品详情界面。在“物品名称”栏选择顾客购买的商品并填写数量,点击“购买”,商品的数量价格就会出现在下方的列表中,并在“总价”一栏显示所有价格,直到将顾客购买的所有商品都录入完毕。图6.购买商品情况界面图6.购买商品情况界面(5)付款 点击“结账”按钮,则进入该界面。在“请你付款”一栏中填入顾客支付的钱,点击“确定”按钮,系统计算得出应找零的数值。图7.付款界面3 相关技术及工具介绍该部分主要介绍系统所采用的技术及开发工具,涉及该系统采用的开发工具及技术,以及该系统涉及的数据库相关知识。3.1 系统采用的开发工具该系统前台采Microsoft 公司的Visual Studio 2010 作为主要的开发工具,可与SQL Server 2008 数据库无缝连接。Visual Studio 2010具有无可比拟的强大功能,使用.NET Framework 3.5 加速开发。.NET Framework 中的构建基块可以很方便的用于解决常见编程任务,能够快速构造出色应用程序。C#是目前流行的一种编程应用程序,C#语言类似拥有类似java的语法,语言简单明了。C#是在Java流行起来后所诞生的一种新的语言。由于微软在操作系统上占有很大的优势。在以往的开发中累积了不少经验,所形成的.net平台,所以C#在Windows方面可以说比Java具有更大的优势。 C#的强大是依赖于.net的发展,而.net的发展是看微软在.net上的决心和投入有多少。1、C#.NET提供了丰富的框架,使用户在无需编写代码的前提下快速进行程序开发。 2、.NET对公共语言运行时的核心进行改进,大大提高了运行速度。3、提高了Windows Presentation Foundation的性能。 4、实体框架是从ADO.NET数据访问技术基础发展而来的。5、LINQ to SQL新增了支持SQL Server2005中新日期和文件流的功能。 6、用于SQL Server的.NET Framework数据提供程序新增了对SQL Server 2005中的文件流和稀疏列功能的支持。3.2 系统采用的技术该系统后台数据库采用Microsoft SQL Server 数据库,该数据库系统在安全性、准确性和运行速度方面有绝对的优势,并且处理数据量大、效率高。SQL Server 2005 包括了几个在企业级数据管理中关键的增强:易管理、可用性、可伸缩性、安全性。SQL Server 2005提供了一个唯一的管理控制台,使得数据管理人员能够在组织内的任何地方监视、管理和调谐企业中所有的数据库和相关的服务。它还提供了一个可扩展的管理架构,可以更容易的用SQL管理对象(SMO)来编程,使得用户可以定制和扩展他们的管理环境。 4 设计总结该部分主要介绍在整个商场购物管理系统实现过程中所遇到的细节性问题以及对今后的展望。 4.1 总结 通过几个月的上机实习,我对C#又有了崭新的认识。 C#的学习是一个系统的过程,需要长期的知识积累和储备并辅以大量的上级实际操作练习,自己也应该有所体会,在实践中成长,在实践中求知。 作为学生,我们更多的是课本的知识的理解,理论的优势是我们的特色,但是怎样将理论结合实际却是摆在我们面前的难题。有些知识虽然我们学过,但是要把它运用到系统中的过程中还出现了很多问题,比如对于控件ListView和DataGridView的使用,在基于多表查询的时候,使用DataGridView这个控件就难以实现在数据库里的多张表的更新,后来我们还是选择了ListView这个控件。从这里让我知道了,只是的学习是没有止境的,我们只有在不断的学习中了解更多,并且能够把所学的知识举一反三,这样我们才能更好的吧实训项目做得更好。 我觉得学习了这个,对我参加工作后制表、创建查询、数据分析和材料演示都有很大的作用,这样,我们能更清楚的了解信息并进行分析。当然实习中还有着更多的感触,包括学习,生活各个方面。就学习而言,专业实训它更偏重于应用,更加细致,要求也更加严格。在实际中实现自己的理想,必需不断的增加自己的能力,做事情更加专注。就生活而言,专业学习展示给我们看各个不同的的实训结果,让我们知道了要善于学习他人的优点。参考教程(1)我要自学网.c#入门教程附 录程序源码: (1) 管理系统namespace 商场管理系统 public partial class Form1 : Form public Form1() InitializeComponent(); private void button1_Click(object sender, EventArgs e) /按下按钮跳转到Form5 界面 Form5 fr = new Form5(); fr.Show(); private void button2_Click(object sender, EventArgs e) /按下按钮跳转到Form7 界面 Form7 fr = new Form7(); fr.Show(); (2) 用户登录 private void button1_Click(object sender, EventArgs e) if (textBox1.Text = "") MessageBox.Show("请输入用户名?"); else if (textBox3.Text = "") MessageBox.Show("请输入密码?"); else try string source = Class1.get_address(); SqlConnection conn = new SqlConnection(source); conn.Open(); string select = "select user,password fromlogin whereuser='" + textBox1.Text + "'andpassword='" + textBox3.Text + "'" SqlCommand cmd = new SqlCommand(select, conn); SqlDataReader dr = cmd.ExecuteReader(); if (dr.HasRows) dr.Close(); /string nwselect = "select * from login where lname='" + textBox1.Text + "'and lpassword='" + textBox3.Text + "'" /SqlCommand nwcmd = new SqlCommand(nwselect, conn); / SqlDataReader nwdr = nwcmd.ExecuteReader(); Form6 mdi = new Form6(); mdi.Show(); else MessageBox.Show("用户名或密码错误, ""); conn.Close(); /this.Hide(); catch (Exception ex) MessageBox.Show(ex.Message); private void button2_Click(object sender, EventArgs e) this.Close(); (3)商品管理namespace 商场管理系统 public partial class Form6 : Form DataSet ds = new DataSet(); SqlDataAdapter da = new SqlDataAdapter(); public Form6() InitializeComponent(); private void button1_Click(object sender, EventArgs e) try string source = Class1.get_address(); SqlConnection conn = new SqlConnection(source); conn.Open(); string insert = "insert into trade values('" + textBox1.Text + "','" + textBox2.Text + "','" + textBox3.Text + "')" SqlCommand cmd = new SqlCommand(insert, conn); cmd.ExecuteNonQuery(); conn.Close(); MessageBox.Show("该物品已添加成功", "提示", MessageBoxButtons.OK); catch (Exception ex) MessageBox.Show(ex.Message); private void button2_Click(object sender, EventArgs e) this.Close(); private void button3_Click(object sender, EventArgs e) try ds.Clear(); string source = Class1.get_address(); SqlConnection conn = new SqlConnection(source); conn.Open(); string select; if (textBox4.Text = "") select = "select * from trade" else select = "select * from trade where name='" + textBox4.Text + "'" da = new SqlDataAdapter(select, conn); da.Fill(ds, "trade"); dataGridView1.AutoGenerateColumns = true; dataGridView1.DataMember = "trade" dataGridView1.DataSource = ds; catch (Exception ex) MessageBox.Show(ex.Message); private void button4_Click(object sender, EventArgs e) SqlCommandBuilder cb = new SqlCommandBuilder(da); da.Update(DataSet)dataGridView1.DataSource).Tables0); MessageBox.Show("已修改成功|"); private void button6_Click(object sender, EventArgs e) try string ss = dataGridView1.RowsdataGridView1.CurrentCell.RowIndex.Cells0.Value.ToString(); /this.dataGridView1.SelectedCells0.Value.ToString(); string source = Class1.get_address(); string insert = "delete trade where name= '" + ss + "'" SqlConnection conn = new SqlConnection(source); conn.Open(); SqlCommand cmd = new SqlCommand(insert, conn); cmd.ExecuteNonQuery(); conn.Close(); MessageBox.Show("你选中的物品·"+ss+"n已经删除成功|", "提示?", MessageBoxButtons.OK); catch (Exception ex) MessageBox.Show(ex.Message); private void button5_Click(object sender, EventArgs e) this.Close(); (4)商品详情namespace 商场管理系统 public partial class Form5 : Form private float Sprice = 0; public Form5() InitializeComponent(); private void InitData() string source = Class1.get_address(); SqlConnection myCon = new SqlConnection(); myCon.ConnectionString = source; myCon.Open(); string Sql = "select name from trade" DataSet Ds = new DataSet(); SqlDataAdapter Da = new SqlDataAdapter(Sql, myCon); Da.Fill(Ds, "trade"); comboBox1.DataSource = Ds.Tables"trade" comboBox1.DisplayMember = "name" myCon.Close(); private void label1_Click(object sender, EventArgs e) private void button1_Click(object sender, EventArgs e) string ss = comboBox1.GetItemText(comboBox1.ItemscomboBox1.SelectedIndex);/获取当前项 if (textBox1.TextLength = 0) MessageBox.Show("请输入购买数量?", ""); else string source = Class1.get_address(); SqlConnection myCon = new SqlConnection(source); myCon.Open(); SqlCommand selectCMD = new SqlCommand("select * from trade where name='" + ss + "'", myCon); SqlDataReader custDR = selectCMD.ExecuteReader(); custDR.Read(); string s1 = custDR.GetString(custDR.GetOrdinal("price"); string s2 = custDR.GetString(custDR.GetOrdinal("num"); custDR.Close(); int q = int.Parse(textBox1.Text); int snum = int.Parse(s2); if (snum < q) MessageBox.Show("对不起,库存不足,只剩余?+s2+"件t商品·",""); else float temp = float.Parse(s1); string S = "" S += q; temp=temp*q; Sprice += temp; string s = "" s = s + Sprice; textBox2.Text = s; snum = snum - q; string sss = "" sss += snum; string ssss="" ssss+=temp; string selectText = "update trade set num = '" + sss + "' where name ='" + ss + "'" SqlCommand CMD = new SqlCommand(selectText, myCon); SqlDataAdapter cus = new SqlDataAdapter(); cus.SelectCommand = CMD; DataSet custD = new DataSet(); cus.Fill(custD); int itemNumber = this.listView1.Items.Count; string subItem = ss, S, ssss ; this.listView1.Items.Insert(itemNumber, new ListViewItem(subItem); this.listView1.ItemsitemNumber.ImageIndex = 0; myCon.Close(); private void Form5_Load(object sender, EventArgs e) InitData(); private void button2_Click(object sender, EventArgs e) string S1 = "" S1 += Sprice; Form2 fr = new Form2(S1); fr.Show(); private void comboBox1_SelectedIndexChanged(object sender, EventArgs e) (5)付款namespace 商场管理系统 public partial class Form2 : Form string money; public Form2(string str) InitializeComponent(); money = str; private void button1_Click(object sender, EventArgs e) float q = float.Parse(money);/花¨费? float w = float.Parse(textBox1.Text); if (w >= q) string s = "" s += w - q; MessageBox.Show("找你" + s + "元!你慢走!"); else MessageBox.Show("对不起钱不够!?");