超市管理信息系统

第一章开发环境和开发工具

1.1  开发背景

    随着科学技术的不断发展,计算机科学日渐成熟,其强大的功能已为人们所深刻认识,它己进入人类社会的各个领域并发挥着越来越重要的作用。采用计算机进行信息化管理已成为衡量企业管理科学化和现代化的重要标志,而超市的进销存管理信息系统的全面自动化、信息化则是现代超市运营体系中重要的组成部分。超市的进销存管理信息系统的好坏对于超市的管理者和用户来说都至关重要,在很大程度上影响着超市其他事务的进行。因此,本文所研究的超市的进销存管理信息系统具有一定的使用价值和现实意义。

    一直以来人们使用传统人工的方式进行超市的进销存管理,这种管理方式存在着诸多缺点,如:工作量大,效率低,保密性差,数据冗余,容易丢失,另外时间一长,将产生大量的文件和数据,不便于整理,这对于查找、更新和维护都带来了不少的困难。鉴于此,本文研究了一种基于关系型数据库的超市信息管理方案。利用SQL Server2005数据库管理系统灵活性和开发效率高的特点,采用面向对象的C#的方法,开发出超市的进销存管理信息系统。该系统具有手工管理所无法比拟的优点,如:检索迅速、查找方便、可靠性高、存储量大、保密性好、信息利用率高、成本低、便于更改等。该系统能够极大地提高超市信息管理的效率,优化学校的人力、物力,降低超市的管理成本,为超市信息管理的信息化、正规化奠定了坚实的基础。

1.2  开发环境

本文所采用的开发环境主要是基于数据库系统的SQL Server 2005和基于面向对象程序设计的C#。利用SQL Server 2005创建超市供应商基本信息表,员工基本信息表,进货表,退货表,销售表,库存表等。利用C#和数据库建立连接之后,利用C#中的控件按钮以及一些程序代码实现一些特定的功能,例如供应商信息查询、供应商信息的修改、供应商信息的增加以及删除,库存信息查询、库存信息的修改、库存信息的增加以及删除等,极大地提高了超市信息管理的效率。


第二章系统的分析与设计

2.1 系统需求分析

超市的进销存信息管理系统是针对超市人事处的大量业务处理工作而开发的管理软件,主要用于超市商品管理,总体任务是实现超市信息关系的系统化、科学化、规范化和自动化,其主要任务是用计算机对商品各种信息进行日常管理,如查询、修改、增加、删除,另外还考虑到库存管理,针对这些要求设计了超市信息管理系统。推行超市信息管理系统的应用是进一步推进超市商品管理规范化、电子化和提高超市管理水平的重要举措。因此开发出一套有效的超市信息管理系统有着重要的意义。

2.2 系统总体设计

2.2.1  系统设计目标

    本文研究开发的超市信息管理系统用于支持超市信息管理工作,有如下三个方面的目标:

(1)支持超市实现规范化的管理。

(2)支持超市高效率完成商品信息管理的日常业务,包括商品入库时商品库存的建立、超市商品的更新等。

(3)支持超市进行信息管理及其相关方面的科学决策,如超市管理人员根据现有的商品数目决定招聘人数,规模的扩建等。

2.2.2  开发设计思想

(1)尽量采用学校现有软硬环境,及先进的管理系统开发方案,从而达到充分利用超市现有资源,提高系统开发水平和应用效果的目的。

(2)系统应符合学校超市信息管理的规定,满足对商品日常管理的需要,并达到操作过程中的直观、方便、实用、安全等要求。

(3)系统采用模块化程序设计方法,既便于系统功能的各种组合和修改,又便于未参与开发的技术维护人员补充、维护。

(4)系统应具备数据库维护功能,及时根据用户需求进行数据的增加、删除、修改、备份等操作。

2.2.3  系统功能模块设计

    本系统分为五个模块:系统用户设置、超市进货信息管理、超市销售信息管理、超市库存信息管理和商品管理。得到如图2-1所示的系统功能模块图。

 

图2-1系统功能模块图


第三章数据库设计

3.1数据库需求分析

    数据库需求分析是数据库结构设计的第一个阶段,也是非常重要的一个阶段。在这个阶段主要工作是收集基本数据以及数据处理的流程,为以后进一步设计一打下基础。需求分析主要解决两个问题::

1. 内容要求。

(1)内容要求。调查应用系统用户所需要操作的数据,决定在数据库中存储什么数据。

(2)处理要求。调查应用系统用户要求对数据库进行什么样的处理,理清数据库中各种数据之间的关系。

2.在数据库需求分析后,得到一个数据字典文档,包括3方面内容。

(1)数据项。包括名称、含义、类型、取值范围、长度以及和其他数据项之间的逻辑关系。

(2)数据结构。若干个数据项的有意义的集合,包括名称、含义以及组成数据结构的数据项。

(3)数据流。指数据中数据的处理过程,包括输入、处理和输出。

3.2  数据库逻辑结构设计

    概念结构是独立于实际数据模型的信息结构,必须将其转化为逻辑结构后才能进行数据库应用的设计。也就是要将概念上的结构转化为BP数据库系统所支持的实际数据模型。

    超市信息管理系统数据库中各个表格的设计结果如下面的六个表所示。每个表表示数据库中的一个表。

供应商表如表3-1所示,主要包括公司的ID、姓名、电话号码、地址等信息。

   

表3-1 供应商表

员工信息表如3-2所示,主要包括员工的编号、姓名、登录名、密码、性别、出生日期等信息。

表3-2 员工信息表

进货表如3-3所示,包括食品的编号、生产日期、生产公司的姓名、进货售出的价格等信息。

  

表3-3进货表

库存信息表如3-4所示,包括食品的编号、生产日期、库存的数量、库存时间等信息。

  

表3-4库存信息表

销售信息表如3-5所示,包括食品名称、售出的数量、售出的时间、售出价格等信息。

表3-5销售信息表

 退货表如3-6所示,包括退货食品编号、售出价格、退货食品名称、退货数量、退货需要的价格等信息。

  

表3-6退货表

第四章系统详细设计与实现

4.1 登陆界面

此界面为登陆界面,用于实现与数据库的连接及进入超市信息管理系统主页面,如图4-2所示。

 

图4-1 登陆界面

4.2主界面

此界面针对于一般用户,在窗体下方会显示登陆者和登录日期,可以查询,浏览信息,如图4-2所示,包括基本信息、进货管理、销售管理、库存管理等信息。

 

图4-2用户登录主界面

4.3   基础信息设置设计

(1)此界面为用户登陆后的进行员工信息相关操作的界面,实现用户对员工信息的增删改查等维护功能,如图4-3所示。

图4-3员工信息界面

(2)此界面为用户登陆后的进行供应商信息相关操作的界面,实现用户对供应商信息的增删改查等维护功能,如图4-4所示。

 

图4-4供应商信息界面

 (3)此界面为用户登陆后的进行库存查询操作的界面,如图4-5所示。

 

图4-5库存查询界面

 (4)此界面为用户登陆后的进行库存警告设置的界面,如图4-6所示。

 

图4-6库存警告界面


心得体会

课程设计诚然是一门专业课,给我很多专业知识以及专业技能上的提升,同时又是一门讲道课,一门辩思课,给了我许多道,给了我很多思,给了我莫大的空间。同时,设计让我感触很深。使我对抽象的理论有了具体的认识。通过这次课程设计,我掌握了信息系统设计的各个环节;熟悉了各种工具软件的操作和应用等等

在此次超市进销存信息管理系统设计当中我认识到开发一项好的软件不是某一个人就能完成的任务。一个团队的小组,一个勤奋的小组非常重要,沟通是解决问题的就好办法。所以小组中的每个成员的能力与协作能力也是致关重要的。同时,不仅是团队内部的交流,更多需要协调好团队之间的交流。我们小组由三名成员组成,相互协作,共同努力,终于准时完成了任务。

首先,我们本次设计中也同样遇到了各种各样的困难,例如一开始就没有真正理解本次设计,没有真正把握住本次设计的主导方向。但是,随着逐步的深入,我们有了方向,并开始根据课程设计的课程表做了工作安排。在设计过程当中,我们对一些知识了解甚浅,无法很好的运用于实践,但是在老师的指导和与同学的交流下,我们逐一排除困难,按计划完成了此次设计的任务。

其次,在超市进销存信息管理系统实习中我了解到,在开发一个系统时一定要先做好规划,做好开发之前的可行性分析,充分了解店里的管理方法和运营状况,按照系统的开发步骤,详细地写好每一个必要的文档。而且,我们也必须事先找一些参考书并根据自己设计方案的特点,来完成这个管理信息的设计。

由于我们能力有限,加上时间仓促,本系统难免会出现一些不足之处,我们深表歉意,如发现还有其它问题,希望老师批评指正。

通过本次设计,我们不但巩固了自己所学的知识而且还把所学知识运用到实践中去,相信对以后的学习有很大的提醒和指导------学习离不开实践。

参考文献

(1)邝孔武,邝志云.管理信息系统分析与设计[M].西安电子科技大学出版社,2006

(2)王珊,李盛恩.数据库基础与应用[M].人民邮电出版社,2005

(3)林锐.软件工程思想[M].西安电子科技大学出版社,2000

(4)James Foxall.Visual C# 2005入门经典[M].人民邮电出版社,2007

(5)严蔚敏,吴伟民.数据结构[M].清华大学出版社,2005。


附录

实现代码如下

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Text;

using System.Windows.Forms;

namespace SupermarketMIS

{

    public partial class frmMain : Form

    {

        public frmMain()

        {

            InitializeComponent();

        }

        //用于传递信息

        public string SendNameValue;

        public frmMain(string strName)

        {

            InitializeComponent();

            SendNameValue = strName;

        }

        //记录登录用户

        private void frmMain_Load(object sender, EventArgs e)

        {

            timer2.Enabled = true;

            this.statusUser.Text = "系统操作员:" + SendNameValue;

        }

        private void timer2_Tick(object sender, EventArgs e)

        {

            this.statusTime.Text = "当前时间:" + DateTime.Now.ToString();

        }

        private void menuEmployee_Click(object sender, EventArgs e)

        {

            //员工信息

            frmEmpInfo empinfo = new frmEmpInfo();

            empinfo.Owner = this;

            empinfo.ShowDialog();

        }

        private void menuCompany_Click(object sender, EventArgs e)

        {

            //供应商信息

            frmCompanyInfo frmComp = new frmCompanyInfo();

            frmComp.Owner = this;

            frmComp.ShowDialog();

        }

        private void menuGoodsIn_Click(object sender, EventArgs e)

        {

            //进货信息

            frmPurchaseGoodsInfo PurchaseGood = new frmPurchaseGoodsInfo();

            PurchaseGood.Owner = this;

            PurchaseGood.ShowDialog();

        }

        private void menuFind_Click(object sender, EventArgs e)

        {

            //商品信息查查询

            frmFindGoods findgood = new frmFindGoods();

            findgood.Owner = this;

            findgood.ShowDialog();

        }

        private void menuSellGoods_Click(object sender, EventArgs e)

        {

            //商品销售信息

            frmSellGoods frmSell = new frmSellGoods();

            frmSell.Owner = this;

            frmSell.ShowDialog();

        }

        private void menuSellFind_Click(object sender, EventArgs e)

        {

            //商品退货信息

            frmReturnGoodsInfo frmReturn = new frmReturnGoodsInfo();

            frmReturn.Owner = this;

            frmReturn.ShowDialog();

        }

        private void menuDepotAlarm_Click(object sender, EventArgs e)

        {

            //库存警报

            frmStockGoodsInfo kcGood = new frmStockGoodsInfo();

            kcGood.Owner = this;

            kcGood.ShowDialog();

        }

        private void menuDepotFind_Click(object sender, EventArgs e)

        {

            //库存查询

            frmStockGoodsFind kcfrmFind = new frmStockGoodsFind();

            kcfrmFind.Owner = this;

            kcfrmFind.ShowDialog();

        }

        private void frmMain_FormClosing(object sender, FormClosingEventArgs e)

        {

            Application.Exit();

        }

namespace SupermarketMIS

{

    public partial class frmCompanyInfo : Form

    {

        public static int intReturn = 0;

        tb_Company Company = new tb_Company();//创建一个tb_Company对象

        tb_CompanyMethod CompanyMethod = new tb_CompanyMethod();//创建tb_CompanyMethod对象,调用tb_CompanyMethod对象的方法可以对供应商进行增、删、改、查

        tb_JhGoodsInfoMethod jhgood = new tb_JhGoodsInfoMethod();//创建一个tb_JhGoodsInfoMethod对象

        public static int intFalg = 0;

        public frmCompanyInfo()//创建一个无参构造方法

        {

            InitializeComponent();

        }

        public frmCompanyInfo(int intResult)//创建一个有参构造方法

        {

            InitializeComponent();

            intReturn = intResult;

        }

        private void ControlStatus()//用于控制按钮的状态

        {

            this.toolSave.Enabled = !this.toolSave.Enabled;

            this.toolAdd.Enabled = !this.toolAdd.Enabled;

            this.toolCancel.Enabled = !this.toolCancel.Enabled;

            this.toolAmend.Enabled = !this.toolAmend.Enabled;

            this.toolDelete.Enabled = !this.toolDelete.Enabled;

        }

        // 将控件恢复到原始状态

        private void ClearControls()

        {

            txtCompanyDirector.Text = "";

            txtCompanyAddress.Text = "";

            txtCompanyFax.Text = "";

            txtCompanyName.Text = "";

            txtCompanyPhone.Text = "";

            txtCompanyRemark.Text = "";

        }

        // 控制控件状态

        public int GetCount()

        {

            int intReslult = 0;

            if (intFalg == 1 || intFalg == 2)

            {

                if (txtCompanyName.Text == "")

                {

                    MessageBox.Show("供应商名称不能为空!", "提示");

                    return intReslult;

                }

                if (txtCompanyPhone.Text == "")

                {

                    MessageBox.Show("联系电话不能为空!", "提示");

                    return intReslult;

                }

                if (txtCompanyDirector.Text == "")

                {

                    MessageBox.Show("地址不能为空!", "提示");

                    return intReslult;

                }

                if (intFalg != 2)

                {

                    Company.intCompanyID = CompanyMethod.tb_CustomerID();

                }

                else

                {

                    Company.intCompanyID = this.dgvCompanyInfo[0, this.dgvCompanyInfo.CurrentCell.RowIndex].Value.ToString();

                }

                Company.intEmpFalg = 0;

                Company.strCompanyAddress = txtCompanyAddress.Text;

                Company.strCompanyDirector = txtCompanyDirector.Text;

                Company.strCompanyFax = txtCompanyFax.Text;

                Company.strCompanyName = txtCompanyName.Text;

                Company.strCompanyPhone = txtCompanyPhone.Text;

                Company.strCompanyRemark = txtCompanyRemark.Text;

                Company.daReDateTime = DateTime.Now;

            }

            if (intFalg == 3)

            {

                if (txtCompanyName.Text == "")

                {

                    MessageBox.Show("供应商名称不能为空!请选择要删除的的记录", "提示");

                    return intReslult;

                }

                Company.intEmpFalg = 1;

                Company.intCompanyID = this.dgvCompanyInfo[0, this.dgvCompanyInfo.CurrentCell.RowIndex].Value.ToString();

            }

            intReslult = 1;

            return intReslult;

        }

        private void frmCompaynInfo_Load(object sender, EventArgs e)

        {

            CompanyMethod.tb_CompanyFind("", 3, dgvCompanyInfo);//窗体一加载,就调用tb_CompanyMethod对象的tb_CompanyFind方法,显示全部供应商的信息

        }

        //保存事件

        private void toolSave_Click(object sender, EventArgs e)

        {

            if (GetCount() == 1)

            {

                if (intFalg == 1)//当inFalg==1时,可以检查表单中的空条件

                {

                    if (CompanyMethod.tb_CompanyMethodAdd(Company) == 1)//调用tb_CompanyMethod对象tb_CompanyMethodAdd()方法,添加供应商,如果CompanyMethod.tb_CompanyMethodAdd(Company) == 1为true,添加并保存成功

                    {

                        if (intReturn == 1)

                        {

                            frmSupplier frmCop = (frmSupplier)this.Owner;//创建一个frmSupplier窗体对象

                            jhgood.filltProd(frmCop.treeView1, frmCop.imageList1);

                            ClearControls(); // 将控件恢复到原始状态

                            ControlStatus();// 控制控件状态

                            intFalg = 0;

                            this.Close();

                        }

                        MessageBox.Show("添加成功");

                        intFalg = 0;

                        CompanyMethod.tb_CompanyFind("", 3, dgvCompanyInfo);//在没有输入添加的情况下,显示所有的供应商的信息

                        ClearControls();

                        ControlStatus();

                    }

                    else//如果CompanyMethod.tb_CompanyMethodAdd(Company) == 1为false,添加失败

                    {

                        MessageBox.Show("添加失败");

                        intFalg = 0;

                        CompanyMethod.tb_CompanyFind("", 3, dgvCompanyInfo);

                        ClearControls();

                        ControlStatus();

                    }

                }

                if (intFalg == 2)//调用tb_CompanyMethod对象tb_CompanyMethodUpdate()方法,修改供应商,如果CompanyMethod.tb_CompanyMethodAdd(Company) == 1为true,修改并保存成功

                {

                    if (CompanyMethod.tb_CompanyMethodUpDate(Company) == 1)

                    {

                        MessageBox.Show("修改成功");

                        intFalg = 0;

                        CompanyMethod.tb_CompanyFind("", 3, dgvCompanyInfo);

                        ClearControls();

                        ControlStatus();

                    }

                    else

                    {

                        MessageBox.Show("修改失败");

                        intFalg = 0;

                        CompanyMethod.tb_CompanyFind("", 3, dgvCompanyInfo);

                        ClearControls();

                        ControlStatus();

                    }

                }

                if (intFalg == 3)

                {

                    if (CompanyMethod.tb_CompanyMethodDelete(Company) == 1)

                    {

                        MessageBox.Show("删除成功");

                        intFalg = 0;

                        CompanyMethod.tb_CompanyFind("", 3, dgvCompanyInfo);

                        ClearControls();

                        ControlStatus();

                    }

                    else

                    {

                        MessageBox.Show("删除失败");

                        intFalg = 0;

                        CompanyMethod.tb_CompanyFind("", 3, dgvCompanyInfo);

                        ClearControls();

                        ControlStatus();

                    }

                }

            }

        }

        //把DataGridView控件中的数据填充到文本控件中去

        private void FillControls()

        {

            try

            {

                //把从数据库中读取的数据填充到DataGridView控件中

                SqlDataReader sqldr = CompanyMethod.tb_CompanyFind(this.dgvCompanyInfo[0, this.dgvCompanyInfo.CurrentCell.RowIndex].Value.ToString());

                sqldr.Read();

                if (sqldr.HasRows)

                {

                    txtCompanyName.Text = sqldr[1].ToString();//把DataGridView控件的第一列填充到txtCompanyName文本控件中

                    txtCompanyDirector.Text = sqldr[2].ToString();//把DataGridView控件的第二列填充到txtCompanyDirector文本控件中

                    txtCompanyPhone.Text = sqldr[3].ToString();//把DataGridView控件的第三列填充到txtCompanyPhone文本控件中

                    txtCompanyFax.Text = sqldr[4].ToString();//把DataGridView控件的第四列填充到txtCompanyFax文本控件中

                    txtCompanyAddress.Text = sqldr[5].ToString();//把DataGridView控件的第五列填充到txtCompanyAddress文本控件中

                    txtCompanyRemark.Text = sqldr[6].ToString();//把DataGridView控件的第六列填充到txtCompanyRemark文本控件中

                }

            }

            catch (Exception ee)

            {

                MessageBox.Show(ee.ToString());

            }

        }

        //取消事件

        private void toolCancel_Click(object sender, EventArgs e)

        {

            ClearControls();//调用ClearControls方法情况所填写的信息

            ControlStatus();//设置按钮的状态

            intFalg = 0;//令intFlag的值为零

        }

        //添加事件

        private void toolAdd_Click(object sender, EventArgs e)

        {

            ControlStatus();

            ClearControls();

            intFalg = 1;//添加标记

        }

        //修改事件

        private void toolAmend_Click(object sender, EventArgs e)

        {

            ControlStatus();

            ClearControls();

            intFalg = 2;//修改标记

        }

        //删除事件

        private void toolDelete_Click(object sender, EventArgs e)

        {

            ControlStatus();

            intFalg = 3;//删除标记

        }

        //按条件查找事件

        private void txtOK_Click(object sender, EventArgs e)

        {

            string P_Str_cmdtxt = String.Empty;

            string P_Str_selectcondition = this.cbxCondition.Text;

            if (P_Str_selectcondition == null)

            {

                MessageBox.Show("请选择查询条件!");

                return;

            }

            if (this.txtKeyWord.Text == "")

            {

                MessageBox.Show("输入查询条件!");

                return;

            }

            switch (P_Str_selectcondition)

            {

                case "供应商名称":

                    CompanyMethod.tb_CompanyFind(txtKeyWord.Text, 1, dgvCompanyInfo);

                    break;

                case "负责人姓名":

                    CompanyMethod.tb_CompanyFind(txtKeyWord.Text, 2, dgvCompanyInfo);

                    break;

                default:

                    break;

            }

        }

        //退出

        private void toolExit_Click(object sender, EventArgs e)

        {

            this.Close();

        }

        //点击DatagridView控件任意的部分所触发的事件

        private void dgvCompanyInfo_CellClick(object sender, DataGridViewCellEventArgs e)

        {

            if (intFalg == 2 || intFalg == 3)//只有intFalg=2(修改)和intFlag=3(删除)时才将DataGridView中选定的数据填充到文本控件中

            {

                FillControls();

            }

        }

    }

}

namespace SupermarketMIS

{

    public partial class frmStockGoodsFind : Form

    {

        public frmStockGoodsFind()

        {

            InitializeComponent();

        }

        tb_KcGoodsInfoMethod tb_GoodMenthd = new tb_KcGoodsInfoMethod();

        tb_KcGoods kcgood = new tb_KcGoods();

        private void btnSearch_Click(object sender, EventArgs e)

        {

            if (this.cmbKey.Text == "")

            {

                MessageBox.Show("请选择查询条件!");

                return;

            }

            if (this.txtKey.Text == "")

            {

                MessageBox.Show("请输入查询信息");

                return;

            }

            switch (cmbKey.Text)

            {

                case "商品编号"://"商品编号":

                    kcgood.strGoodsID = txtKey.Text;

                    tb_GoodMenthd.tb_ThGoodsFind(this.dgvStockInfo, 1, kcgood);

                    break;

                case "商品名称"://商品名称"

                    kcgood.strKcGoodsName = txtKey.Text;

                    tb_GoodMenthd.tb_ThGoodsFind(this.dgvStockInfo, 2, kcgood);

                    break;

            }

        }      

    }

}

namespace SupermarketMIS

{

    public partial class frmStockGoodsInfo : Form

    {

        public frmStockGoodsInfo()

        {

            InitializeComponent();

        }

        tb_KcGoods kcGood = new tb_KcGoods();

        tb_KcGoodsInfoMethod tb_GoodMenthd = new tb_KcGoodsInfoMethod();

        private void frmStockGoodsInfo_Load(object sender, EventArgs e)

        {

            tb_GoodMenthd.tb_ThGoodsFind(dgvStockInfo, 4, kcGood);

        }

        private void FillControls()

        {

            try

            {

                SqlDataReader sqldr = tb_GoodMenthd.tb_ThGoodsFind(this.dgvStockInfo[0, this.dgvStockInfo.CurrentCell.RowIndex].Value.ToString());

                sqldr.Read();

                if (sqldr.HasRows)

                {

                    txtID.Text = sqldr[1].ToString();

                    txtGoodsName.Text = sqldr[2].ToString();

                    txtGoodsJhPrice.Text = sqldr[9].ToString();

                    txtGoodsSellPrice.Text = sqldr[10].ToString();

                    txtGoodsNum.Text = sqldr[5].ToString();

                }

                sqldr.Close();

            }

            catch (Exception ee)

            {

                MessageBox.Show(ee.ToString());

            }

        }

        public void ClearFill()

        {

            txtID.Text = "";

            txtGoodsName.Text = "";

            txtGoodsJhPrice.Text = "";

            txtGoodsSellPrice.Text = "";

            txtGoodsNum.Text = "";

        }

        private void btnAdd_Click(object sender, EventArgs e)

        {

            if (txtID.Text == "")

            {

                MessageBox.Show("请选择商品信息");

                return;

            }

            if (txtNum.Text == "")

            {

                MessageBox.Show("请输入商品警报数量");

                return;}

            int intResult = tb_GoodMenthd.tb_KcGoodsUpdate(txtID.Text, Convert.ToInt32(txtNum.Text));

            if (intResult == 1)

            {

                MessageBox.Show("添加成功!");

                tb_GoodMenthd.tb_ThGoodsFind(this.dgvStockInfo, 4, kcGood);

                ClearFill();

            }

            else

            {MessageBox.Show("添加失败!");

                ClearFill();

            }

        }

        private void btnExit_Click(object sender, EventArgs e)

        {

            this.Close();

        }

        private void txtNum_KeyPress(object sender, KeyPressEventArgs e)

        {

            if (!char.IsDigit(e.KeyChar))

            {

                MessageBox.Show("请输入数字");

                e.Handled = true;

            }

        }

        private void dgvStockInfo_CellClick(object sender, DataGridViewCellEventArgs e)

        {

            FillControls();

        }

    }

}


目  录

第一章 开发环境和开发工具.... 1

1.1  开发背景.... 1

1.2  开发环境.... 1

第二章 系统的分析与设计.... 2

2.1 系统需求分析.... 2

2.2 系统总体设计.... 2

2.2.1  系统设计目标.... 2

2.2.2  开发设计思想.... 2

2.2.3  系统功能模块设计.... 3

第三章 数据库设计.... 4

3.1 数据库需求分析.... 4

3.2  数据库逻辑结构设计.... 4

第四章 系统详细设计与实现.... 8

4.1 登陆界面.... 8

4.2主界面.... 8

4.3   基础信息设置设计.... 8

心得体会.... 11

参考文献.... 12

附录.... 13

相关推荐