《超市销售管理信息系统.pdf》由会员分享,可在线阅读,更多相关《超市销售管理信息系统.pdf(14页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、摘要摘要本文针对超市销售管理信息系统,以超市销售信息系统为背景,通过对超市的日常业务进行详细调研与研究,对其工作流程进行研究,建立销售信息处理模型,并在此基础上设计销售信息管理软件的方案,并加以实施。本文主要对该超市的现状进行了需求分析,达到了相应的用户需求,功能需求以及相应的业务流程,重点阐述了系统的分析、设计的思路和方法,以及系统数据库设计的方法。建立超市销售管理系统使超市销售管理工作规范化,系统化,程序化,避免管理的随意性,提高信息处理的速度和准确性,能够及时、准确、有效地进行信息查询和修改.提高了直接或间接的经济效益,提升超市销售管理和行政管理水平,改善顾客和超市成员关系,增强超市服务
2、竞争力,实现优质服务。关键词:关键词:超市销售信息管理系统 数据库前言前言随着经济发展人们生活水平的提高,人们消费需求提高物品需求种类多样化,超市销售管理的数据结构及处理也日益复杂.超市服务系统不仅要求准确无误地保留有关经济数据,而且要求迅速可靠地采用各种数据信息进行综合分析和决策。计算机所具有的数字化技术和交互式的处理能力,使其对数据庞大、程序复杂的各类信息进行综合处理,从而为超市经济管理的运行提供决策依据。本文阐述了超市管理系统的设计与实现,以顾客为中心,以时间为轴线,围绕顾客消费过程,详细地、完整地收集所有数据.借助于信息系统的杠杆作用,平衡顾客与超市的需要,将管理信息和顾客信息做集成,
3、使得相关人员在任何时间、任何地点都能得到相关信息。其主要目标是协助完成超市对日常的计算机服务统计和销售管理等业务,减轻超市人员处理业务的劳动强度。一、系统需求分析一、系统需求分析1、系统概述系统分析是系统开发的重要阶段,其目的是要回答系统将要“做什么“,即需求分析.完成需求分析之后,对系统的涉及到的部门进行组织结构分析和业务流程分析.在此基础之上还要做数据流程分析,并利用数据字典对数据流程进行详细的说明。本系统由六个表组成。分别是:供应商表、商品信息表、交易表、会员表、销售表以及入库表.每个表实现不同的功能。主要是为了超市人员的添、删、改、查。提高超市人员的工作效率和工作质量,全面提高了超市的
4、综合管理水平和服务质量,提高顾客满意度,同时为超市带来一定的经济效益产生积极作用。2、实现功能超市销售管理系统主要实现为了超市人员方便添、删、改、查,提高工作效率,对销售情况一目了然。供应商表主要实现:快速了解供应商的基本信息,比如:编号、姓名、地址、电话。通过查询供应商的编号,就可以对他们的信息有所了解.商品信息表主要实现:快速了解商品的基本信息。比如:商品编号、商品名、商品供应商、商品价格、商品销售日期、商品进货日期、商品库存数量。通过查找商品编号,就可以知道此商品的一系列信息.交易表主要实现:交易的记录。比如:交易编号、交易日期、交易价格、会员卡号.通过查找交易编号,可以知道交易的一切信
5、息。会员表主要实现:会员的基本信息。比如:会员编号、会员卡号、会员姓名、会员性别、会员联系方式以及会员地址。通过查找会员编号,可以一目了然的知道此会员的信息。销售表主要实现:销售的记录。比如:交易编号、商品编号、销售数量、销售价格。通过查找交易编号和商品编号可以快速查找到销售的所有记录。入库表主要实现:入库商品的信息。比如:入库编号、入库商品编号、单额、总额、入库日期、入库数量以及入库状态。通过查找入库编号,就可以了解入库商品的所有信息。3、划分功能模块供应商供应商供应商编号供应商姓名商品编号供应商地址商品名会员卡号供应商电话商品供应商会员性别会员编号二、数据库的设计二、数据库的设计1、数据库
6、表的设计交易价格数据库共交易编号7 个表,分别是:商品信息表,会员表,供应商表,交入库商品编会员表商品信息表商品信息表号易表,销售表,入库表以及 Admin 表。入库日期入库编号商品价格交易表以下分别是每个表的内容:销售表商品信息表入库表会员表交易表Admin 表以上为商品信息表,会员表,供应商表,交易表,销售表,入库表以及Admin 表的内容.数据流图:2、数据库链接程序package chapter00jdbc.exammanager;import java。awt.*;import java.awt.event。;import javax。swing.*;import javax。swi
7、ng.event。;import chapter00jdbc。exammanager。db。DBAdmin;import chapter00jdbc.exammanager。mygui.*;public class TestFrame extends JFrame private static JDesktopPane theDesktop;JMenuItem loginItem,exitItem,helpItem;/登录”、”退出”和帮助内容”菜单项final String itemString=”管理员,会员”;final JPanel itemPanel =new PanelAdmin(
8、超市销售信息管理系统”,Admin”),newPanelhuiyuanBiao(超市销售信息管理系统”,会员表”);JMenuItem item=new JMenuItemitemPanel.length;/题库管理菜单的 4 个菜单项:3 个表和生成试卷public TestFrame()super(超市销售信息管理系统”);/1.登录菜单:有两个菜单项”登录和”退出”JMenu loginMenu=new JMenu(”登录”);JMenuItem loginItem=new JMenuItem(登录);loginMenu.add(loginItem);loginItem.addActio
9、nListener(new ActionListener()public void actionPerformed(ActionEvent e)String name=JOptionPane。showInputDialog(null,请输入登陆名字:);String password=JOptionPane。showInputDialog(null,请输入登陆密码:”);if(DBAdmin.isAdmin(name,password))JOptionPane.showMessageDialog(null,”登录成功!);for(int i=0;iitem。length;i+)itemi.se
10、tEnabled(true);elseJOptionPane。showMessageDialog(null,密码不对,登录失败!”););JMenuItem exitItem=new JMenuItem(退出”);loginMenu。add(exitItem);exitItem。addActionListener(new ActionListener()public void actionPerformed(ActionEvent e)System.exit(0););/2。题库管理”菜单:库中的每个表对应一个菜单项,实现添、删、改、查;”导出试卷菜单项JMenu adminMenu=new
11、JMenu(超市销售信息管理系统”);for(int i=0;iitem。length;i+)itemi=builedAdminMenuItem(adminMenu,itemStringi,itemPaneli);/3。帮助菜单JMenu helpMenu=new JMenu(帮助”);JMenuItem helpItem=new JMenuItem(”帮助内容”);helpMenu.add(helpItem);helpItem。addActionListener(new ActionListener()public void actionPerformed(ActionEvent e)JOp
12、tionPane。showMessageDialog(TestFrame.this,”运行程序后,看相应的代码););/4.创建菜单条,添加菜单JMenuBar bar=new JMenuBar();setJMenuBar(bar);bar.add(loginMenu);bar。add(adminMenu);bar。add(helpMenu);/5.窗口中间放置桌面面板,用来显示内部窗口theDesktop=new JDesktopPane();getContentPane()。add(theDesktop,BorderLayout。CENTER);setSize(800,600);setVi
13、sible(true);/创建菜单项的通用方法:参数menu 是菜单项所添加在其上的菜单;/参数 itemName 是菜单项的名字,因其在匿名内部类对象中引用,必须声明为final;/参数 panel 是点击菜单项后所生成的内部窗口中的面板对象,必须声明为final.private JMenuItem builedAdminMenuItem(JMenu menu,final String itemName,finalJPanel panel)final JMenuItem menuItem=new JMenuItem(itemName);menu。add(menuItem);menuItem。
14、setEnabled(false);menuItem。addActionListener(new ActionListener()public void actionPerformed(ActionEvent e)buildInternalFrame(panel,itemName,menuItem);/生成内部窗口);return menuItem;/生成内部窗口:窗口中间放置面板对象。参数item 是与内部窗口相关的菜单项。private void buildInternalFrame(JPanel panel,String title,final JMenuItem item)JInter
15、nalFrame frame=new JInternalFrame(title,true,true,true,true);/内部窗口frame。addInternalFrameListener(new InternalFrameAdapter()/内部窗口监听:关闭后执行public void internalFrameClosed(InternalFrameEvent e)item.setEnabled(true);/关闭内部窗口时,菜单项item 可用.);Container container=frame。getContentPane();/内部窗口容器面板container。add(p
16、anel,BorderLayout。CENTER);/参数面板 panel 放在容器中间frame.setSize(600,480);theDesktop。add(frame);/内部窗口添加到桌面面板才能显示frame.setVisible(true);item。setEnabled(false);/生成内部窗口后,与之相关的菜单项item 不可用。/测试 TestFrame 类public static void main(String args)JFrame frame=new TestFrame();frame。setDefaultCloseOperation(JFrame。EXIT_
17、ON_CLOSE);3、数据库表的添、删、改、查/添加记录protected void dealAddbtn()huiyuan a1=new huiyuan();/改成你的beana1。setBianhao(fields0.getText().trim();/顺序要对,fields里的序号要和表的字段的顺序一样a1.setKahao(fields1。getText()。trim());a1。setXingming(fields2。getText()。trim();a1。setXingbie(fields3。getText().trim());a1.setLianxifangshi(fields
18、4。getText().trim();a1。setDizhi(fields5.getText().trim());DBhuiyuan。addHuiyuan(a1);/改成你的DBbeanJOptionPane。showMessageDialog(null,”添加成功);tableModel.setQuery(会员表”);/改成你的表名/修改记录protected void dealUpdatebtn()huiyuan a1=new huiyuan();/改成你的beana1。setBianhao(fields0。getText().trim();/顺序要对,fields里的序号要和表的字段的顺
19、序一样a1。setKahao(fields1。getText()。trim());a1。setXingming(fields2.getText()。trim();a1.setXingbie(fields3.getText().trim();a1.setLianxifangshi(fields4。getText()。trim();a1.setDizhi(fields5.getText()。trim());DBhuiyuan.updatehuiyuanbiao(a1);/改成你的DBbeanJOptionPane。showMessageDialog(null,修改成功);tableModel.se
20、tQuery(”会员表);/改成你的表名/删除记录protected void dealDelbtn()DBhuiyuan。deletehuiyuanbiao(fields0.getText().trim();/改成你的DBbeanJOptionPane。showMessageDialog(null,”删除成功);tableModel.setQuery(”会员表);/改成你的表名/查询记录protected void dealQuerybtn()huiyuan hy=DBhuiyuan.gethuiyuan(fields0。getText());fields1.setText(hy。getKa
21、hao());fields2.setText(hy.getXingming();fields3。setText(hy。getXingbie();fields4。setText(hy。getLianxifangshi();fields5.setText(hy.getDizhi());JOptionPane.showMessageDialog(null,”查询成功);tableModel。setQuery(会员表”);/改成你的表名三、图形界面设计与实现三、图形界面设计与实现登陆界面登陆成功表的操作界面登陆界面程序:package chapter00jdbc。exammanager;import
22、java.awt。*;import java。awt.event。*;import javax。swing.;import javax。swing.event。*;import chapter00jdbc。exammanager。db.DBAdmin;import chapter00jdbc.exammanager.mygui。;public class TestFrame extends JFrame private static JDesktopPane theDesktop;JMenuItem loginItem,exitItem,helpItem;/登录”、退出”和帮助内容”菜单项fi
23、nal String itemString=管理员”,”会员”;final JPanel itemPanel=new PanelAdmin(超市销售信息管理系统”,Admin),new PanelhuiyuanBiao(超市销售信息管理系统”,”会员表);JMenuItem item=new JMenuItemitemPanel.length;/”题库管理菜单的 4 个菜单项:3 个表和”生成试卷public TestFrame()super(超市销售信息管理系统);/1。登录菜单:有两个菜单项-登录”和退出”JMenu loginMenu=new JMenu(登录”);JMenuItem l
24、oginItem=new JMenuItem(登录”);loginMenu.add(loginItem);loginItem。addActionListener(new ActionListener()public void actionPerformed(ActionEvent e)String name=JOptionPane。showInputDialog(null,请输入登陆名字:”);String password=JOptionPane。showInputDialog(null,请输入登陆密码:);if(DBAdmin。isAdmin(name,password)JOptionPa
25、ne.showMessageDialog(null,”登录成功!”);for(int i=0;iitem。length;i+)itemi.setEnabled(true);elseJOptionPane。showMessageDialog(null,”密码不对,登录失败!”););JMenuItem exitItem=new JMenuItem(退出);loginMenu。add(exitItem);exitItem.addActionListener(new ActionListener()public void actionPerformed(ActionEvent e)System。ex
26、it(0););/2。题库管理菜单:库中的每个表对应一个菜单项,实现添、删、改、查;导出试卷”菜单项JMenu adminMenu=new JMenu(”超市销售信息管理系统);for(int i=0;iitem。length;i+)itemi=builedAdminMenuItem(adminMenu,itemStringi,itemPaneli);/3.”帮助菜单JMenu helpMenu=new JMenu(帮助);JMenuItem helpItem=new JMenuItem(帮助内容);helpMenu.add(helpItem);helpItem.addActionListen
27、er(new ActionListener()public void actionPerformed(ActionEvent e)JOptionPane。showMessageDialog(TestFrame。this,”运行程序后,看相应的代码”););/4.创建菜单条,添加菜单JMenuBar bar=new JMenuBar();setJMenuBar(bar);bar.add(loginMenu);bar.add(adminMenu);bar.add(helpMenu);/5.窗口中间放置桌面面板,用来显示内部窗口theDesktop=new JDesktopPane();getCon
28、tentPane().add(theDesktop,BorderLayout。CENTER);setSize(800,600);setVisible(true);/创建菜单项的通用方法:参数menu 是菜单项所添加在其上的菜单;/参数 itemName 是菜单项的名字,因其在匿名内部类对象中引用,必须声明为final;/参数 panel 是点击菜单项后所生成的内部窗口中的面板对象,必须声明为final。private JMenuItem builedAdminMenuItem(JMenu menu,final String itemName,finalJPanel panel)final JM
29、enuItem menuItem=new JMenuItem(itemName);menu。add(menuItem);menuItem.setEnabled(false);menuItem.addActionListener(new ActionListener()public void actionPerformed(ActionEvent e)buildInternalFrame(panel,itemName,menuItem);/生成内部窗口);return menuItem;/生成内部窗口:窗口中间放置面板对象。参数item 是与内部窗口相关的菜单项。private void bui
30、ldInternalFrame(JPanelpanel,String title,final JMenuItem item)JInternalFrame frame=new JInternalFrame(title,true,true,true,true);/内部窗口frame.addInternalFrameListener(new InternalFrameAdapter()/内部窗口监听:关闭后执行public void internalFrameClosed(InternalFrameEvent e)item.setEnabled(true);/关闭内部窗口时,菜单项item 可用。)
31、;Container container=frame。getContentPane();/内部窗口容器面板container.add(panel,BorderLayout。CENTER);/参数面板 panel 放在容器中间frame.setSize(600,480);theDesktop。add(frame);/内部窗口添加到桌面面板才能显示frame。setVisible(true);item。setEnabled(false);/生成内部窗口后,与之相关的菜单项item 不可用。/测试 TestFrame 类public static void main(String args)JFra
32、me frame=new TestFrame();frame。setDefaultCloseOperation(JFrame。EXIT_ON_CLOSE);四、程序测试package chapter00jdbc.exammanager;import java。awt.;import java。awt。event.*;import javax.swing.;import javax。swing.event.*;import chapter00jdbc.exammanager。db。DBAdmin;import chapter00jdbc.exammanager.mygui。;public cla
33、ss TestFrame extends JFrame private static JDesktopPane theDesktop;JMenuItem loginItem,exitItem,helpItem;/”登录、退出和”帮助内容”菜单项final String itemString=”管理员”,”会员;final JPanel itemPanel=new PanelAdmin(”超市销售信息管理系统,Admin),new PanelhuiyuanBiao(超市销售信息管理系统,会员表”);JMenuItem item=new JMenuItemitemPanel.length;/题库管
34、理菜单的 4 个菜单项:3 个表和”生成试卷public TestFrame()super(”超市销售信息管理系统”);/1。登录”菜单:有两个菜单项-登录和退出”JMenu loginMenu=new JMenu(”登录);JMenuItem loginItem=new JMenuItem(”登录);loginMenu.add(loginItem);loginItem.addActionListener(new ActionListener()public void actionPerformed(ActionEvent e)String name=JOptionPane.showInput
35、Dialog(null,请输入登陆名字:”);String password=JOptionPane.showInputDialog(null,请输入登陆密码:);if(DBAdmin。isAdmin(name,password)JOptionPane.showMessageDialog(null,”登录成功!);for(int i=0;iitem.length;i+)itemi.setEnabled(true);elseJOptionPane。showMessageDialog(null,密码不对,登录失败!););JMenuItem exitItem=new JMenuItem(退出”);
36、loginMenu.add(exitItem);exitItem.addActionListener(new ActionListener()public void actionPerformed(ActionEvent e)System。exit(0););/2。”题库管理菜单:库中的每个表对应一个菜单项,实现添、删、改、查;导出试卷菜单项JMenu adminMenu=new JMenu(超市销售信息管理系统”);for(int i=0;iitem。length;i+)item i=builedAdminMenuItem(adminMenu,itemStringi,itemPaneli);
37、/3.帮助菜单JMenu helpMenu=new JMenu(”帮助”);JMenuItem helpItem=new JMenuItem(”帮助内容”);helpMenu.add(helpItem);helpItem。addActionListener(new ActionListener()public void actionPerformed(ActionEvent e)JOptionPane.showMessageDialog(TestFrame。this,运行程序后,看相应的代码”););/4.创建菜单条,添加菜单JMenuBar bar=new JMenuBar();setJMe
38、nuBar(bar);bar.add(loginMenu);bar。add(adminMenu);bar.add(helpMenu);/5.窗口中间放置桌面面板,用来显示内部窗口theDesktop=new JDesktopPane();getContentPane().add(theDesktop,BorderLayout。CENTER);setSize(800,600);setVisible(true);/创建菜单项的通用方法:参数 menu 是菜单项所添加在其上的菜单;/参数 itemName 是菜单项的名字,因其在匿名内部类对象中引用,必须声明为final;/参数 panel 是点击菜
39、单项后所生成的内部窗口中的面板对象,必须声明为 final.private JMenuItem builedAdminMenuItem(JMenu menu,final String itemName,finalJPanel panel)final JMenuItem menuItem=new JMenuItem(itemName);menu。add(menuItem);menuItem.setEnabled(false);menuItem。addActionListener(new ActionListener()public void actionPerformed(ActionEvent
40、 e)buildInternalFrame(panel,itemName,menuItem);/生成内部窗口);return menuItem;/生成内部窗口:窗口中间放置面板对象。参数item 是与内部窗口相关的菜单项。private void buildInternalFrame(JPanel panel,String title,final JMenuItem item)JInternalFrame frame=new JInternalFrame(title,true,true,true,true);/内部窗口frame。addInternalFrameListener(new Int
41、ernalFrameAdapter()/内部窗口监听:关闭后执行public void internalFrameClosed(InternalFrameEvent e)item。setEnabled(true);/关闭内部窗口时,菜单项item 可用。);Container container=frame.getContentPane();/内部窗口容器面板container.add(panel,BorderLayout.CENTER);/参数面板 panel 放在容器中间frame.setSize(600,480);theDesktop。add(frame);/内部窗口添加到桌面面板才能显
42、示frame.setVisible(true);item。setEnabled(false);/生成内部窗口后,与之相关的菜单项item 不可用./测试 TestFrame 类public static void main(String args)JFrame frame=new TestFrame();frame.setDefaultCloseOperation(JFrame。EXIT_ON_CLOSE);五、结论五、结论通过这次 JAVA 实验的实训,总的来说,受益匪浅.在这些天中,我们学到了很多东西,比如对,对添、删、改、查的操作更加熟悉。开始很困难,由于老师的帮助,后来慢慢的熟悉起来,
43、最重要的是我们有机会用电脑自己进行实践,没接触的时候总觉得它比较深奥或者不可接近的新型语言.开始做的时候,不知道从何做起,不懂得话不知道怎么问,从什么地方学起。后来,参加了这次实训,从基本到做完,一步一步的离不开老师和同学的帮助,使我对 JAVA 这门课程更感兴趣了.对于语句的编写,开始摸不着路,后来照着教材,一点一滴的学起,慢慢的也懂了,编起来不再那么费劲了.实训课是在学习与探索中度过的,短暂的三天实训结束了,但其中让我们学到很多知识,在老师帮助下,一步一步的做完实训课程,谢谢朱老师老师的帮助,使我对JAVA 又有了新的认识,新的了解,新的进步。这学期的 JAVA 也是有所收获。三、数据库的
44、实施运行三、数据库的实施运行1、管理表和会员的添、删、改、查2、程序实现商品信息抓图入库表抓图供应商抓图销售表抓图会员抓图交易抓图四、结论四、结论通过这次数据库实验的实训,总的来说,受益匪浅。在这些天中,我们学到了很多东西,比如对数据库的建表,对添、删、改、查的操作更加熟悉.知道表的内容越丰富越好,用语句建表开始还是很困难的,后来慢慢的熟悉起来,最重要的是我们有机会用电脑自己进行实践,没接触的时候总觉得它比较深奥或者不可接近的新型语言。开始做的时候,不知道从何做起,不懂得话不知道怎么问,从什么地方学起.后来,参加了这次实训,从基本到做完,一步一步的离不开老师和同学的帮助,使我对数据库这门课程更感兴趣了.对于 SQL 语句的编写,开始摸不着路,后来照着教材,一点一滴的学起,慢慢的也懂了,编起来不再那么费劲了。实训课是在学习与探索中度过的,短暂的三天实训结束了,但其中让我们学到很多知识,在老师帮助下,一步一步的做完实训课程,谢谢魏魏老师的帮助,使我对数据库又有了新的认识,新的了解,新的进步。这学期的数据库也是有所收获。