admin 管理员组文章数量: 887192
2024年1月13日发(作者:编程语言排行17)
沈 阳 工 程 学 院
课 程 设 计
设计题目: 面向对象程序设计课程设计
小超市管理系统
课程设计任务书
课程设计题目:
面向对象程序设计课程设计
小超市管理系统
I
目 录
摘 要 .................................................................................................................... 错误!未定义书签。
第1章 绪 论 .................................................................................................................................. 1
第2章 系统功能介绍 ........................................................................................................................ 2
2.1系统功能总框图 ..................................................................................................................... 2
2.2 本系统模块功能介绍 ............................................................................................................ 2
2.2.1 登录功能介绍 .............................................................................................................. 2
2.2.2 商品销售功能介绍 ...................................................................................................... 3
2.2.3 权限管理功能介绍 ...................................................................................................... 3
2.2.4 销售管理功能介绍 ...................................................................................................... 4
2.2.5 商品管理功能介绍 ...................................................................................................... 4
2.3 组内任务分工 ........................................................................................................................ 5
第3章 数据库设计 ............................................................................................................................ 6
3.1 数据库需求分析 .................................................................................................................... 6
3.2 数据库概念结构设计 ............................................................................................................ 6
3.3 数据库表的设计 .................................................................................................................... 7
第4章 系统功能实现 ........................................................................................................................ 8
4.1 登录功能实现 ........................................................................................................................ 8
4.2 销售界面功能介绍 .............................................................................................................. 11
4.2.1 搜索商品的信息 ........................................................................................................ 11
4.2.2 购买商品 .................................................................................................................... 11
4.2.3 模块的核心代码 ........................................................................................................ 12
4.3 权限管理功能介绍 .............................................................................................................. 18
4.3.1 添加用户功能介绍 .................................................................................................... 18
4.3.2 修改用户功能介绍 .................................................................................................... 19
4.3.3 删除用户功能介绍 .................................................................................................... 19
4.3.4 显示用户信息与刷新按钮介绍 ................................................................................ 20
4.3.5 用户管理的实现代码……………………………………………………………....20
4.4销售管理功能介绍 ............................................................................................................... 27
4.4.1 编号查询功能 ............................................................................................................ 27
4.4.2 账单查询功能 ............................................................................................................ 27
4.4.3 销售管理模块的核心代码 ........................................................................................ 28
4.4商品管理功能介绍 ............................................................................................................... 31
4.4.1 查询信息 .................................................................................................................... 31
4.4.2 添加信息及提交添加 ................................................................................................ 32
4.4.3 删除信息及提交删除 ................................................................................................ 32
4.4.4
修改信息及提交修改 .................................................................................................... 33
4.4.5 关于 ............................................................................................................................ 33
4.4.6 模块的核心代码……………………………………....……………………………34
总 结 ................................................................................................................................................ 39
致 谢 ................................................................................................................................................ 40
参考文献 ............................................................................................................................................ 41
II
沈阳工程学院课程设计报告 第1章 绪论
第1章 绪 论
随着人们生活水平的不断提高,购物已成为一种时尚。每天都有大量的消费者在各大商场中留下消费信息,所以作为商场的管理人员就需要有一个自动化、智能化的管理系统来完成这些信息的处理。由此我们设计开发小超市管理系统。
目前市场上的超市管理系统,大部分为基于分布式数据库的网络管理系统,对于规模较小的超市没有必要花巨资来购买这样功能全面的管理系统,此外,对于那样功能齐全的管理系统也需要花大精力来维护。基于这种情况,我们用所学的java知识,可以开发一种既能节约资金,又能完成小超市日常的管理任务。
本系统所包括的功能主要有:限于不同身份的人登录的登录界面;权限管理功能;商品销售功能;商品管理功能;销售管理功能。
在系统的设计中,用户管理功能可以管理登录本系统的人员,如:管理员、用户和超级用户等。在最初的系统使用中只有技术管理员一种身份。商品销售功能;可以完成商品信息的查询。如:输入一种商品的编号在商品信息栏就显示该商品的所有信息,名称、价格、生产日期、生产地。然后选择购买功能,就可以将商品添加到购物信息栏,最后选择提交,所购买的商品信息同时也添加到数据库中。在商品管理功能中,可以把一种新引进的商品信息添加到小超市管理系统中。在销售管理功能中,可以查看超市的销售情况,所有商品的购买信息都存储在数据库中。
在系统的安全性方面,我们规定了不同权限的登录用户,管理员(主要负责用户管理)可以登录到任何一个管理模块,以及后台的数据库,能够改变任一个登录者的用户名和密码。用户只能进入到销售界面。老板超级主要查看商品的销售情况和商品管理,他可以进入到商品销售管理查看商品的销售情况。通过这样的权限限制就可以方便的控制系统的安全性。
总之,小超市管理系统是一个经济、实惠的应用软件,适合小规模的商店和超市。操作难度小,易学易用。
- 1 -
沈阳工程学院课程设计报告 第2章 系统功能介绍
第2章 系统功能介绍
2.1系统功能总框图
小超市管理系统是一个专门针对小型的商店和超市的智能化、自动化的管理系统。其功能总框图如图2-1所示。
超市管理系统登陆销售商品销售管理商品管理用户管理查询商品
购买商品提交购买信息清空购买的商品商品号查询账单查询商品销售信息添加商品信息删除商品更新用户修改用户权限图2-1 系统功能总框图
2.2 本系统模块功能介绍
2.2.1 登录功能介绍
登录功能是进入系统必须经过的验证过程,其主要功能是验证使用者的身份,确认使用者的权限,从而在使用软件过程中能安全地控制系统数据,即不同的工作人员有不同的权限,每个使用人员不得跨越其权限操作软件,可以避免不必要的数据丢失事件发生。
登录的界面如图2-2所示:
图2-2登录的界面
- 2 -
沈阳工程学院课程设计报告 第2章 系统功能介绍
2.2.2 商品销售功能介绍
销售界面是本系统直接供销售的店员应用的专管销售功能的界面,首先要查询欲购买的商品,在左侧的查询框内输入商品代号,然后点击搜索按钮,相应的商品信息将显示在“商品信息”一栏中,确认是此商品后点击购买,购买的商品将出现在下面的购物信息一栏中,当所有欲购买的商品都已输入好,点击提交,购买的商品信息将记录到数据库中。若输入有误,点击清除按钮,刚输入的信息将被清除,可重新输入。界面的右下方右商品总价的标签,可以时时地显示已购买商品的总价,以供参考。商品销售功能的主界面如图2-3所示:
图2-3销售窗口的主界面
2.2.3 用户管理功能介绍
用户管理功能是管理人员使用的界面。管理人员可以使用此功能管理所有登录用户的信息。可以修改所有用户的帐号和密码,设置用户的权限,删除用户的帐号;对于已存在的用户技术管理员可以查询他们的信息,在下面的显示用户信息处显示。添加、修改、删除等操作后,单击“刷新”后,新的更改信息才可以在下面的用户信息显示处显示。
用户管理的主界面如图2-4所示:
图2-4 用户管理的主界面
- 3 -
沈阳工程学院课程设计报告 第2章 系统功能介绍
2.2.4 销售管理功能介绍
销售管理功能主要是老板查看超市商品销售情况。老板可以根据已售出的商品号查询该商品的信息,如可以查询该商品已售出的总数量。还可以根据销售的账单号查询,就是在消费者每一次购买商品时,就分配一个账单号,如出现消费者退货情况时,老板可以查询账单号解决。
“按编号查询”输入商品的编号,在下面的商品信息处显示该商品的信息;“按账单号查询”输入商品的账单号,在下面的商品信息处显示该商品的信息。
销售管理功能的主界面如图2-5所示:
图2-5商品管理功能主界面
2.2.5 商品管理功能介绍
商品管理的功能是店员在进货、商品信息维护时所需要的界面,此界面功能是管理所有商品的信息,在这里可以添加、修改、删除任意商品信息,做到对商品信息的及时维护。
应用时,对应按钮的功能,进行应用,维护方便。
商品管理功能的主界面如图2-6所示:
- 4 -
沈阳工程学院课程设计报告 第2章 系统功能介绍
图2-6商品管理系统的主界面
2.3 组内任务分工
组内人员分工如表2-1所示:
表2-1 组内分工
组内分工
组长
组员
组员
组员
姓名
王浩
魏兴龙
王潇伯
夏恩亮
主要任务
数据库的设计、商品管理和用户管理等功能
销售管理界面及功能
商品销售界面及功能
权限销售界面及功能
成绩
- 5 -
沈阳工程学院课程设计报告 第3章 数据库的设计
第3章 数据库设计
在每个管理系统中都一定有储存机制,若单单以文件形式储存,查找和存储时速度比较缓慢,会降低系统的整体运行速度,一定要运用数据库的进行信息管理,所以我们的“小超市管理系统”运用了Microsoft Access数据库,存储其后台数据。下面将介绍本系统的数据库设计。
3.1 数据库需求分析
此系统需要有两个实体,账户和商品。
数据项如表3-1和3-2所示。
表3-1用户信息数据项
数据项名
ID
PASSWORD
PERSONTY
数据项含义说明
用户登录的帐号
用户登录帐号对应的密码
登录用户的权限
别名
Id
Psw
Pst
数据类型
字符型
字符型
字符型
长度
50
50
50
表3-2商品信息数据项
数据项名
NUM
NAME
TIME
ADD
PRICE
COUNT
数据项含义说明
商品的编号
商品的名称
商品的进货时间
商品的生产地址
商品的单价
商品的库存数量
别名
编号
名称
货时
产地
价格
数量
数据类型
字符型
字符型
字符型
字符型
整型
整型
长度
50
50
50
50
50
3.2 数据库概念结构设计
根据需求分析设计出E-R图如图3-1所示:
编号名称商品单价产地库存数量权限N进货日期账号管理1用户密码
图3-1 系统E-R图
- 6 -
沈阳工程学院课程设计报告 第3章 数据库的设计
3.3 数据库表的设计
Password表,其中存储的是用户的帐号、密码及权限,用于登陆系统时确认身份。此表设计如3-3表所示:
表3-3 Password信息表
字段名称
ID
PASSWORD
PERSONTY
数据类型
文 本
文 本
文 本
长 度
50
50
50
备 注
Goods表,其中存储的是商品的详细信息,作用是记录商品的信息及在本超市中的数量。此表设计如3-4标所示。
表3-4Goods信息表
字段名称
NUM
NAME
PRICE
TIME
ADD
COUNT
数据类型
文 本
文 本
整 型
文 本
文 本
文 本
长 度
50
50
50
50
50
备 注
Information表,其中存储的是顾客在超市中的消费情况,其中有帐单号、商品代号、数量及总价,用来记录超市中销售情况,此表设计如3-5表所示。
表3-5 Information信息表
字段名称
编号
LISTNUM
GOODSNUM
ALLPRICE
数据类型
长 整 型
文 本
文 本
整 型
长 度
50
50
备 注
销售的每件商品有不同的编号
每提交一次帐单帐单号增加1
每个帐单的最后合出此帐单的总价
- 7 -
沈阳工程学院课程设计报告 第4章 系统功能实现
第4章 系统功能实现
4.1 登录功能实现
登录界面是使用者在使用此软件时需要输入自已的账号和密码,从而使用自已的权限来管理超市的运行。
小超市登录界面如4-1所示。
图4-1 小超市管理系统登录界面
模块核心代码:
public class Login extends Frame implements ActionListener,WindowListener //登陆界面
{
public int screanWidth,screanHeight;
String idin=null;
String keyin=null;
String passwordD=null;
public static String persontyD=null;
MenuBar menubar;
Menu menu;
MenuItem quet,help;
Label id,key;
TextField idtf,keytf;
Box boxV1,boxV2,boxV3,baseBox,boxx;
Button enterB;
Login()
{ setTitle("超市管理系统登陆界面");
Toolkit tool=getToolkit();
Dimension dim=eenSize();
screanWidth=;
screanHeight=;
setBounds(/3,/3,320,215);
menubar=new MenuBar();
menu=new Menu("功能");
help=new MenuItem("帮助");
- 8 -
沈阳工程学院课程设计报告 第4章 系统功能实现
quet=new MenuItem("退出");
rtcut(new MenuShortcut(_E));
ionListener(new ActionListener() //匿名类实例控制
{
public void actionPerformed(ActionEvent p){
(0);
}} );
(help);
(quet);
(menu);
setMenuBar(menubar);
id=new Label("请输入帐号:",);
key=new Label("请输入密码:",);
idtf=new TextField(10);
keytf=new TextField(10);
oChar('*');
enterB=new Button("登陆");
boxV1=VerticalBox();
(VerticalStrut(35));
(id);
(VerticalStrut(15));
(key);
(VerticalStrut(15));
boxV2=VerticalBox();
(VerticalStrut(35));
(idtf);
(VerticalStrut(15));
(keytf);
(VerticalStrut(15));
baseBox=HorizontalBox();
(HorizontalStrut(25));
(boxV1);
(HorizontalStrut(5));
(boxV2);
(HorizontalStrut(70));
boxV3=HorizontalBox();
(HorizontalStrut(125));
(enterB);
(HorizontalStrut(125));
boxx=VerticalBox();
(baseBox);
(VerticalStrut(15));
(boxV3);
(VerticalStrut(70));
add(boxx);
ionListener(this);
- 9 -
沈阳工程学院课程设计报告 第4章 系统功能实现
addWindowListener(this);
setResizable(false);
setVisible(true);
}
public void actionPerformed(ActionEvent e)
{ Connection con;
Statement sql;
ResultSet rs;
if (rce()==enterB)
{ idin=t();
keyin=t();
try { e("bcDriver"); }
catch (ClassNotFoundException f)
{n(""+f);}
try
{con=nection("jdbc:odbc:q","","");
sql=Statement();
rs=eQuery("SELECT * FROM password where ID='"+idin+"'");
while(()){
passwordD=ing(2);
persontyD=ing(3);}
();}
catch (SQLException g)
{n(g);}
if ((passwordD))
{View2 frame=new View2();
ible(false); }
else {ssageDialog(this," 帐户或密码错误n
请重新输入","提示",G_MESSAGE); } } }
public void windowActivated(WindowEvent o)
{validate();}
public void windowDeactivated(WindowEvent o)
{setBounds(screanWidth/3,screanHeight/3,320,215);
validate();}
public void windowClosing(WindowEvent o)
{dispose();}
public void windowClosed(WindowEvent o)
{(0);}
public void windowIconified(WindowEvent o)
{}
public void windowDeiconified(WindowEvent o)
{setBounds(screanWidth/3,screanHeight/3,320,215);
validate();}
public void windowOpened(WindowEvent o){}
}
- 10 -
沈阳工程学院课程设计报告 第4章 系统功能实现
4.2 销售界面功能介绍
该功能是此系统的最关键的模块,是消费者直接使用的功能。消费者可以根据已看到的商,在搜索栏中打入商品的编号,进行查询商品的信息,然后可以依椐自已的需要购买。最后单击提交,购买的商品就记录到系统的数据库中。
销售的主界面如图4-2所示:
图 4-2 销售的主界面
4.2.1 搜索商品的信息
消费者可根据自已所需要的商品编号,在销售功能中搜索,查看商品的信息无误后,确定是否购买。如搜索001号商品,查看它的信息,如图4-3所示。
图4-3 搜索001号商品的信息
4.2.2 购买商品
在确定自已需要的商品后,然后就是购买商品,消费者可以按“购买”键进行购买物品,购买一份就单击一次“购买”键,购买物品的信息显示在购物信息框中,最后单击“提交”,消费者所购买的物品就作为一个账单号存储在数据库中。
如购买004、005、006、008、010和011号商品时,购买信息如图4-4下:
- 11 -
沈阳工程学院课程设计报告 第4章 系统功能实现
图4-4 购买信息
当购买人不想购买这些商品时,可以点击窗口左下角的清除按钮,来清除刚才购买的商品,数据库中也不会有此记录。
此外,本系统是每购买一件商品向数据库提交一次记录,当未点击提交按钮之前,若要结束此窗口进程,我们在代码中嵌入了一段删除当前帐单的数据库记录代码,以达到没有误提交的操作。
4.2.3 模块的核心代码
⑴ 销售界面的实现
public class View2 extends JFrame implements ActionListener //销售界面
{
String num=null,name=null,time=null,add=null,t1=null,t2=null,t3=null;
int price=0;
int n1,n2,ap,n3;
private JPanel sM=new JPanel(); //supermarket面板
private JButton[] pS={new JButton("销售界面"),new JButton("销售管理"),
new JButton("商品管理"),new JButton("权限管理")};//personty 按钮
private JTextArea goodsShow=new JTextArea(), searchShow=new JTextArea(); //文本区
private JScrollPane jsp=new JScrollPane(goodsShow); //滚动区域 设定内容为 商品显示的文本区
private JTextField numSearch=new JTextField(),showGoods=new JTextField(); //商品查询/显示商品
private JButton searchGoods=new JButton("搜索"),buyGoods=new JButton("购买"),
clean=new JButton("清空"), ok=new JButton("提交"),print=new JButton("打印并提交"); //查询按钮
private JLabel[] goodsInformation={new JLabel("商品编码",),new JLabel("商品名称- 12 -
沈阳工程学院课程设计报告 第4章 系统功能实现
",),
new JLabel("商品价格",),new JLabel("生产日期",),new JLabel("生产地",) };
private JLabel[] goodsI={new JLabel("商品编码",),new JLabel("商品名称",),
new JLabel("商品价格",),new JLabel("生产日期",),new JLabel("生产地",) } ;
private JLabel allPrice=new JLabel("商品总价:n ",),label1=new JLabel("商品信息
",),label2=new JLabel("购物信息 ",);
public View2()
{
out(null);
for(int i=0;i<4;i++)
{
pS[i].setBounds(550+i*110,50,100,22);
(pS[i]);
pS[i].addActionListener(this);
}
nds(100,180,800,500);
eWrap(true)
nds(100,50,150,22);
nds(260,50,60,22);
ionListener(this);
nds(330,50,60,22);
ionListener(this);
nds(100,120,800,22);
for (int b=0;b<5 ;b++ )
{
goodsInformation[b].setBounds(100+160*b,87,160,30);
(goodsInformation[b]);
}
for (int b=0;b<5 ;b++ )
{
goodsI[b].setBounds(100+160*b,150,160,30);
(goodsI[b]);
}
nds(100,690,100,22);
ionListener(this);
nds(690,690,100,22);
ionListener(this);
nds(800,690,100,22);
ionListener(this);
nds(900,480,100,50);
nds(20,120,80,22);
nds(20,180,80,22);
(label1);
- 13 -
沈阳工程学院课程设计报告 第4章 系统功能实现
(label2);
(allPrice);
(print);
(ok);
(showGoods);
(clean);
(numSearch);
(searchGoods);
(buyGoods);
(jsp);
addWindowListener(new WindowAdapter() {
public void windowClosing(WindowEvent e) {
Connection con;
Statement sql;
ResultSet rs;
try
{
if (n3!=0)
{
int a1=0;
con=nection("jdbc:odbc:q","","");
sql=Statement();
rs=eQuery("SELECT MAX(编号) from information");
while(())
{
a1=(1);}
for (int i=0;i { eUpdate("delete from information where 编号="+(a1-i)); } (); ap=0; num=null;name=null;price=0;time=null;add=null;n3=0; t(null); } } catch (SQLException g) {n(g); } (0); } }); (sM); le("销售窗口"); izable(false); nds(0,0,1024,768); - 14 - 沈阳工程学院课程设计报告 第4章 系统功能实现 ible(true); validate(); } ⑵ 购买商品功能的代码 if(rce()==buyGoods) //购买按键 { try { if (num!=null) {con=nection("jdbc:odbc:q","",""); sql=Statement(); eUpdate("insert into information(listnum,goodsnum) values('"+n2+"','"+num+"')"); rs=eQuery("SELECT * FROM information where listnum="+n2); n3++;//记录购买商品个数 (); (" "+num+" "+name+" "+price+" "+time+" "+add+"n"); } else {ssageDialog(this,"请选择商品","提示",G_MESSAGE);} ap=ap+price;//总价 t("商品总价:n"+ap); } catch (SQLException g) {n(g); } } if(rce()==ok) { try { if (n3!=0) { con=nection("jdbc:odbc:q","",""); sql=Statement(); eUpdate("insert into information(listnum,allprice) values('"+n2+"','"+ap+"')"); rs=eQuery("SELECT * FROM information where listnum="+n2); (); ap=0; num=null;name=null;price=0;time=null;add=null;n3=0; t(null); n2++;//帐单号 } else - 15 - 沈阳工程学院课程设计报告 第4章 系统功能实现 {ssageDialog(this,"请购买商品","提",G_MESSAGE);} } catch (SQLException g) {n(g); } } if(rce()==print) { try { if (n3!=0) { con=nection("jdbc:odbc:q","",""); sql=Statement(); eUpdate("insert into information(listnum,allprice) values('"+n2+"','"+ap+"')"); rs=eQuery("SELECT * FROM information where listnum="+n2); (); ap=0; num=null;name=null;price=0;time=null;add=null;n3=0; t(null); n2++;//帐单号 } else {ssageDialog(this,"请购买商品","提",G_MESSAGE);} } catch (SQLException g) {n(g); } } if(rce()==clean) { try { if (n3!=0) { int a1=0; con=nection("jdbc:odbc:q","",""); sql=Statement(); rs=eQuery("SELECT MAX(编号) from information"); while(()) { a1=(1);} for (int i=0;i { eUpdate("delete from information where 编号="+(a1-i)); } (); ap=0; num=null;name=null;price=0;time=null;add=null;n3=0; t(null);} } - 16 - 示示 沈阳工程学院课程设计报告 第4章 系统功能实现 catch (SQLException g) {n(g);} } ⑶ 搜索商品的代码实现 if (rce()==searchGoods) { num=t(); try { e("bcDriver"); } catch (ClassNotFoundException f) {n(""+f);} try { con=nection("jdbc:odbc:q","",""); sql=Statement(); rs=eQuery("SELECT * FROM goods where num='"+num+"'"); while(()){ name=ing(2); price=(3); time=ing(4); add=ing(5); n1=1;} ();} catch (SQLException g) {n(g); } if (n1==1) { t(" "+num+" "+name+" "+price+" "+time+" "+add); n1=0; } else { t(" "); num=null;name=null;price=0;time=null;add=null; ssageDialog(this," 输入错误n 请重新输入","提示",G_MESSAGE); }} ⑷ 提交商品的代码 if(rce()==ok) { try { if (n3!=0) { con=nection("jdbc:odbc:q","",""); sql=Statement(); eUpdate("insert into information(listnum,allprice) values('"+n2+"','"+ap+"')"); rs=eQuery("SELECT * FROM information where listnum="+n2); (); ap=0; num=null;name=null;price=0;time=null;add=null;n3=0; t(null); - 17 - 沈阳工程学院课程设计报告 第4章 系统功能实现 n2++;//帐单号} else {ssageDialog(this,"请购买商品","提示",G_MESSAGE);}} catch (SQLException g) {n(g);} 4.3 用户管理功能介绍 在用户管理部分,主要功能是控制小超市内用户的权限,不同的职位具有不同的权限,具有不同的ID和密码。在这部分当中,可以针对超市的情况对工作人员的信息实现添加用户、修改用户和删除用户的功能,并且超市内所有人员的信息都可以通过显示用户信息区域显示出来。界面的设计简单明了,将setLayout布局设为空,然后再向面板上添加组件,通过坐标值控制各组件的位置。权限管理界面如图4-5所示。 图4-5 用户管理界面 4.3.1 添加用户功能介绍 在添加用户行所对应的文本框中输入要添加用户的ID、PASSWORD、PERSONTY,单击添加按钮,“添加”按钮上已添加了监控器,在按钮被触发后,将会向“ID”、“PASSWORD”、“PERSONTY”所对应的文本框索取数据,只有当该用户在数据库中没有相应记录,并且添加的信息完整时才会显示添加成功,若所添加的信息不完整,则显示“请输入完整信息”,若信息完整,但该用户已存在,则显示“添加失败!原因:可能数据库添加失败或已有此ID”。添加用户功能如图4-6所示。 - 18 - 沈阳工程学院课程设计报告 第4章 系统功能实现 (a) (b) 图4-6 添加用户 4.3.2 修改用户功能介绍 修改部分的操作方法与添加部分相类似,但是输入的是修改后的用户信息,“修改”按钮也添加了监控器,单击“修改”按钮后,会将新输入的“ID”、“PASSWORD”、“PERSONTY”信息返回到数据库中,替代原来的信息。同样的,输入的信息必须完整,修改的ID数据库中必须存在。修改用户功能如图4.7所示。 图4.7 修改用户 4.3.3 删除用户功能介绍 删除用户部分的操作,只需要输入用户的ID,然后点击“删除”按钮,由于删除按钮上也添加了监控器,当按钮被触发后,会从删除用户对应的文本框获取数据(即ID号码),再返回数据库,将该ID对应的信息删除。删除用户信息如图4-8所示。 (a) (b) 图4-8 删除用户 - 19 - 沈阳工程学院课程设计报告 第4章 系统功能实现 4.3.4 显示用户信息与刷新按钮介绍 设置显示用户信息区域的主要目的是将数据库中的用户信息显示出来,然而该区域只能显示在进入系统时的数据库信息,对于之后的修改等操作后的信息无法更新,所以添加了“刷新”按钮,使心事的信息更新,刷新的实质是将该界面关闭再重新打开,从而达到更新数据的目的。 4.3.5 用户管理的实现代码 用户管理的实现代码如下: import .*; import .*; import .*; import .*; import .*; import .*; public class View3 extends JFrame implements ActionListener { String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=D:"; private JPanel v3=new JPanel(); private JLabel idl1=new JLabel("ID",),idl2=new JLabel("ID",),idl3=new JLabel("ID",),passwordl1=new JLabel("PASSWORD",),passwordl2=new JLabel("PASSWORD",),perl1=new JLabel("PERSONTY",),perl2=new JLabel("PERSONTY",); private JLabel[] cho={new JLabel("添加用户",),new JLabel("修改用户",),new JLabel("删除用户",),new JLabel("显示用户信息",)}; private JTextField id1=new JTextField(),id2=new JTextField(),id3=new JTextField(),password1=new private JButton[] pS={new JButton("销售界面"),new JButton("销售管理"), new JButton("商品管理"),new JButton("用户管理")}; private JButton[] cB={new JButton("添加"),new JButton("修改"),new JButton("删除")}; private JButton addin=new JButton("添加"),updatein=new JButton("修改"),dele=new JButton("修改"); private JComboBox per1=new JComboBox(str),per2=new JComboBox(str); private JTextArea jtas=new JTextArea(); private JButton reShow=new JButton("刷新"); Connection con;//连接对象 - 20 - JTextField(),password2=new JTextField(); private String[] str={"无","管理员","超级用户","用户"}; private JScrollPane jsp=new JScrollPane(jtas); 沈阳工程学院课程设计报告 第4章 系统功能实现 ResultSet rs;//结果集 Statement st; nds(200,171,150,22);nds(370,171,150,22);nds(540,171,100,22); nds(200,200,150,22); nds(200,222,150,22); nds(865,273,90,22); ionListener(this); try { Connection con; nds(200,149,150,22);nds(370,149,150,22);nds(540,149,100,22); nds(200,120,150,22);nds(370,120,150,22);nds(540,120,100,22); View3() { out(null); for(int i=0;i<4;i++) { pS[i].setBounds(550+i*110,50,100,22); (pS[i]); pS[i].addActionListener(this); } for (int i=0;i<4 ;i++ ) {cho[i].setBounds(50,120+i*51,140,22); (cho[i]); } for (int i=0;i<3 ;i++ ) {cB[i].setBounds(680,120+i*51,80,22); (cB[i]); cB[i].addActionListener(this); } nds(200,98,150,22);nds(370,98,150,22);nds(540,98,100,22); Statement sql; ResultSet rs; con=nection(url); rs=eQuery("SELECT * from password"); while(()) - 21 - sql=Statement(); 沈阳工程学院课程设计报告 第4章 系统功能实现 { String a1=ing(1); String a2=ing(2); String a3=ing(3); (" 帐号:"+a1+" 密码:"+a2+" 权限:"+a3+"n"); } } {n(g); } (); catch (SQLException g) nds(200,273,650,420); (reShow); (jsp); (per1); (per2); (perl1); (perl2); (idl1); (id1); (idl2); (id2); (idl3); (id3); (passwordl1); (password1); (passwordl2); (password2); addWindowListener(new WindowAdapter() { public void windowClosing(WindowEvent e) { (0); } }); (v3); le("权限管理"); izable(false); nds(0,0,1024,768); ible(true); validate(); - 22 - 沈阳工程学院课程设计报告 第4章 系统功能实现 } //连接数据库 public void conDB() { String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=D:"; try { e("bcDriver"); } catch (ClassNotFoundException e) { ssageDialog(null, "数据库操作错误或失败!"); } try { con = nection(url); st = Statement(); } catch (SQLException e) { ssageDialog(null, "数据库连接失败!"); } } //关闭数据库 public void closeDB() { try { (); (); } catch (SQLException e) { ssageDialog(null, "数据库关闭失败!"); } } public void actionPerformed(ActionEvent e) { { if(rce()==reShow) View3 fr=new View3(); dispose(); //提交添加用户操作 { if (rce() == cB[0]) if ((t().trim()).equals("") || (t().trim()).equals("") || (ectedIndex()==0 )) { ssageDialog(null, "请输入完整信息!"); - 23 - 沈阳工程学院课程设计报告 第4章 系统功能实现 } else { String userid = t(); String username =t(); String userpwd =ectedItem().toString(); n(userpwd+"11111111"); String strSQL = "insert into password values('" +userid+ "','" +username+ "','" + userpwd+"')"; try { conDB(); eUpdate(strSQL); closeDB(); } catch (Exception exx) { n(exx); ssageDialog(this, "添加失败! 原因:有可能数据库联接失败或以由此ID,尝试换个ID添加"); return; } ssageDialog(this, "添加成功!"); t(""); t(""); ectedIndex(0); } } //提交修改用户操作 if (rce() == cB[1]) { if ((t().trim()).equals("") || (t().trim()).equals("") || (ectedIndex()==0 )) { ssageDialog(null, "请输入完整信息!"); } else { String userid = t(); String username =t(); String userpwd =ectedItem().toString(); n(userpwd+"11111111"); - 24 - 沈阳工程学院课程设计报告 第4章 系统功能实现 String strSQL ="update password set personty='" + userpwd + "',password='" + username +"'where ID='" + userid +"'"; try { conDB(); int a=eUpdate(strSQL); closeDB(); if (a==0) {ssageDialog(this, "无此id信息,修改失败!"); return; } } catch (Exception exx) { n(exx); ssageDialog(this, "数据库原因,修改失败!"); return; } ssageDialog(this, "修改成功!"); t(""); t(""); ectedIndex(0); } } //提交删除用户操作 if (rce() == cB[2]) ) { ssageDialog(null, "请输入完整信息!"); } else { String userid = t(); String strSQL ="delete from password where ID='" + userid +"'"; try { conDB(); int a=eUpdate(strSQL); closeDB(); if (a==0) {ssageDialog(this, "没有此用户 删除失败!"); - 25 - { if ((t().trim()).equals("") 沈阳工程学院课程设计报告 第4章 系统功能实现 return; } } catch (Exception exx) { n(exx); ssageDialog(this, "没有此用户 删除失败!"); return; } ssageDialog(this, "删除成功!"); t(""); }} if(rce()==pS[0]) {View2 ve=new View2(); dispose();} if(rce()==pS[1]) { if(("管理员")||("超级用户")||("用户")) { sale2 frame1=new sale2(); } else } if(rce()==pS[2]) { if(("管理员")||("超级用户")) { } else } } ssageDialog(null, "对不起,您没有进入权限!"); Frm_Main frame=new Frm_Main(); dispose(); ssageDialog(null, "对不起,您没有进入权限!"); dispose(); - 26 - 沈阳工程学院课程设计报告 第4章 系统功能实现 4.4销售管理功能介绍 销售管理功能主要是老板了解商品的销售情况,他可以登录进来,按已销售商品的编号和商品的账单号来查询商品的销售情况。也可以查询商品的售出的数量,当按编号查询时,后面的数量表示已售出商品的数量;当按账单号进行查询时,后面的数量表示消费者一次购买时,不同商品的总数。从而了解哪些商品销售的好,对商品的进货做出决定。 商品管理功能的界面如图4-9所示。 图4-9 商品管理功能界面 4.4.1 编号查询功能 在已销售出的商品中,可以按照它的编号来进行查询,以显示售出商品的各种信息。其中最后的信息“数量”表示已售出商品的数量。如:查询002号商品的销售情况,该商品一共卖出0份。如图4-10所示。 图4-10 002号商品的销售情况 4.4.2 账单查询功能 每一种商品在销售时,都有用户提交的一份账单,也就是流水号查询。消费者购买物品时,可以一次购买不同的商品,商品的编号不同,但是一次购买的账单号是一样的,账号查- 27 - 沈阳工程学院课程设计报告 第4章 系统功能实现 询的功能就是查询消费者一次购买的商品。这个功能还可以防止消费者的结账出错时的查询,一次就可以查询出消费者的购买信息,解决错账的情况。 如查询流水号是0号的消费者的购买情况,在这一次的交易中销售如图4-11所示。 图4-11按账单查询情况 4.4.3 销售管理模块的核心代码 ⑴ 销售面板的实现 public sale2() { label1=new JLabel("按编号查询",); label2=new JLabel("按帐单查询",); field1=new JTextField(30);field2=new JTextField(30); button1=new JButton("查询1");button2=new JButton("查询2"); out(null); nds(100,120,150,22); nds(600,120,150,22); nds(100,90,150,30); nds(600,90,150,30);nds(260,120,80,22); nds(760,120,80,22); ionListener(this);ionListener(this); (label1);(label2);(field1);(field2);(button1);(button2); for(int i=0;i<4;i++) { pS[i].setBounds(550+i*110,50,100,22); (pS[i]); pS[i].addActionListener(this); } for(int i=0;i<7;i++) { (CD[i]);} //6个标签的绘制 CD[i].setBounds(100+i*115,160,115,20); nds(100,180,800,500); eWrap(true); addWindowListener(new WindowAdapter() { public void windowClosing(WindowEvent e) { (0); } }); - 28 - 沈阳工程学院课程设计报告 第4章 系统功能实现 (jsp); (sM); le("销售窗口"); izable(false); nds(0,0,1024,768); ible(true); } ⑵ 查询过程的处理 public void actionPerformed(ActionEvent p) { Connection con,con1; Statement sql,sql1; ResultSet rs,rs1; if (rce()==button1) { String num=t(); try { e("bcDriver"); } catch (ClassNotFoundException f) {n(""+f);} try { con=nection("jdbc:odbc:q","",""); sql=Statement(); rs=eQuery("SELECT count(goodsnum) FROM information goodsnum='"+num+"'"); while(()) { countBG=(1); n(countBG);} rs=eQuery("SELECT * FROM goods where num='"+num+"'"); while(()) {name=ing(2); price=(3); time=ing(4); add=ing(5); n1=1;} ();} catch (SQLException g) {n(g);} if (n1==1) { (" (物品销售量查询) "+name+" "+price+" "+add+" "+countBG+"n"); n1=0; } else - 29 - where "+num+" "+time+" 沈阳工程学院课程设计报告 第4章 系统功能实现 { }} if(rce()==pS[0]) { View2 frame=new View2(); dispose();} num=null;name=null;price=0;time=null;add=null; ssageDialog(this," 输入错误n 请重新输入","提示",G_MESSAGE); if(rce()==pS[2]) { Frm_Main frame=new Frm_Main(); dispose();} if(rce()==pS[3]) { View3 frame=new View3(); dispose(); } if (rce()==button2) { String numb=t(); int num=nt(numb); try { e("bcDriver"); } catch (ClassNotFoundException f) {n(""+f);} try {con=nection("jdbc:odbc:q","",""); sql=Statement(); rs=eQuery("SELECT while(()) { con1=nection("jdbc:odbc:q","",""); sql1=Statement(); String number=ing(1); countBG=(2); n(countBG+number+name+time+price+add); rs1=eQuery("SELECT * FROM goods where num='"+number+"'"); while (()) { name=ing(2); goodsnum,count(goodsnum) FROM information where listnum="+num+" group by goodsnum"); price=(3); time=ing(4); add=ing(5); "+num+" (" "+number+" "+name+" "+price+" "+time+" "+add+" "+countBG+"n"); } - 30 - 沈阳工程学院课程设计报告 第4章 系统功能实现 } (); } catch (SQLException g) {n(g); }}}} (); 4.4商品管理功能介绍 该模块主要实现对商品的信息管理功能,主要功能包括查询、添加、删除、修改商品信息,商品的主要信息包括商品编号、商品名称、商品价格、生产日期、生产地、库存量。商品管理界面如图4-12所示。 图4-12 商品管理界面 4.4.1 查询信息 点击“查询信息”,出现如图4-13(a)所示的对话框,填入所查询商品的编号,然后点击“确定”,若存在所查询的商品,将在左面的信息栏中中显示商品信息;若不存在,则将出现如图4-13(b)所示的对话框,提示无商品信息。 (a)输入查询商品编号 (b) 无商品信息提示 图4-13 查询的界面 - 31 - 沈阳工程学院课程设计报告 第4章 系统功能实现 4.4.2 添加信息及提交添加 点击“添加信息”后,会出现如图4-14所示的对话框,提示输入信息;当信息输入完毕后,点击提交添加,若输入正确,会出现如图4-15(a)所示的对话框,提示添加成功,若输入不完全,有空项未添,则会出现如图4-15(b)所示的对话框,提示添加错误。当添加成功后,信息栏会自动变为空。 图4-14 提示输入信息 (a) 添加成功 (b) 添加错误 图4-15添加商品 4.4.3 删除信息及提交删除 点击“删除信息”后,会出现如图4-16所示的对话框,提示所要删除商品的名称,输入后点击“确定”,若输入的商品存在,在左面的信息栏中会显示所要删除的商品信息,再点击“提交删除”后,会出现如图4-17(a)所示的对话框,提示删除成功;若输入的商品不存在,则会出现如图4-17(b)所示的对话框,提示无商品信息。当删除成功后,信息栏会自动变为空。 图4-16 输入商品名称 - 32 - 沈阳工程学院课程设计报告 第4章 系统功能实现 (a) 删除成功 (b) 无商品信息提示 图4.17删除商品 4.4.4 修改信息及提交修改 点击“修改信息”后,会出现如图4-18所示的对话框,提示所要修改商品的名称,输入后点击“确定”,若输入的商品存在,在左面的信息栏中会显示所要修改的商品信息,修改完毕后,点击“提交修改”,会出现如图4-19(a)所示的对话框,提示修改成功;若输入的商品不存在,则会出现如图4-19(b)所示的对话框,提示无商品信息。修改成功后,信息栏会自动变为空。 图4-18 输入商品编号 (a) 修改成功 (b) 无商品信息提示 图4-19 修改商品 4.4.5 关于 当商品有问题或对超市有任何意见和建议时,可通过“关于”上的联系方式与主管部门取得联系。如图4-20所示。 - 33 - 沈阳工程学院课程设计报告 第4章 系统功能实现 图4-20 联系电话提示 4.4.6 模块的核心代码 import .*; import .*; import .*; import .*; public class sale2 extends JFrame implements ActionListener //销售界面 { private JPanel sM=new JPanel(); //supermarket面板 JLabel label1,label2; JTextField field1,field2; JButton button1,button2; String num=null,name=null,time=null,add=null,t1=null,t2=null,t3=null; int price=0,countBG,n1;// 价格/商品的卖出数量 private JTextArea goodsShow=new JTextArea(); //文本区 private JScrollPane jsp=new JScrollPane(goodsShow); //滚动区域 设定内容为 商品显示的文本区 private JButton[] pS={new JButton("销售界面"), new JButton("销售管理"), new JButton("商品管理"), new JButton("用户管理")}; //personty 按钮 private JLabel[] CD={new JLabel("清单号",), new JLabel("编号",), new JLabel("名称",), new JLabel("价格",), new JLabel("生产日期",), new JLabel("产地",), new JLabel("数量",)}; //帐单查询时的商品显示标签 public sale2() { label1=new JLabel("按编号查询",); - 34 - 沈阳工程学院课程设计报告 第4章 系统功能实现 label2=new JLabel("按帐单查询",); field1=new JTextField(30); field2=new JTextField(30); button1=new JButton("查询1"); button2=new JButton("查询2"); out(null); nds(100,120,150,22); nds(600,120,150,22); nds(100,90,150,30); nds(600,90,150,30); nds(260,120,80,22); nds(760,120,80,22); ionListener(this); ionListener(this); (label1); (label2); (field1); (field2); (button1); (button2); for(int i=0;i<4;i++) { pS[i].setBounds(550+i*110,50,100,22); (pS[i]); pS[i].addActionListener(this); } for(int i=0;i<7;i++) //6个标签的绘制 { CD[i].setBounds(100+i*115,160,115,20); (CD[i]); } nds(100,180,800,500); eWrap(true); addWindowListener(new WindowAdapter() { public void windowClosing(WindowEvent e) { (0); } }); (jsp); (sM); - 35 - 沈阳工程学院课程设计报告 第4章 系统功能实现 le("销售窗口"); izable(false); nds(0,0,1024,768); ible(true); } public void actionPerformed(ActionEvent p) { Connection con,con1; Statement sql,sql1; String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=D:"; ResultSet rs,rs1; if (rce()==button1) { String num=t(); try { e("bcDriver"); } catch (ClassNotFoundException f) { n(""+f); } try { con=nection(url); sql=Statement(); rs=eQuery("SELECT count(goodsnum) FROM information goodsnum='"+num+"'"); while(()) { countBG=(1); n(countBG); } rs=eQuery("SELECT * FROM goods where num='"+num+"'"); while(()) { name=ing(2); price=(3); time=ing(4); add=ing(5); n1=1; } (); } catch (SQLException g) - 36 - where 沈阳工程学院课程设计报告 第4章 系统功能实现 {n(g); } if (n1==1) { (" (物品销售量查询) "+num+" "+name+" "+price+" "+time+" "+add+" "+countBG+"n"); n1=0; } else { //t(" "); num=null;name=null;price=0;time=null;add=null; ssageDialog(this," 重新输入","提示",G_MESSAGE); } } if(rce()==pS[0]) { View2 frame=new View2(); dispose(); } if(rce()==pS[2]) { Frm_Main frame=new Frm_Main(); dispose(); } if(rce()==pS[3]) { View3 frame=new View3(); dispose(); } if (rce()==button2) { String numb=t(); int num=nt(numb); try { e("bcDriver"); } catch (ClassNotFoundException f) { n(""+f); } - 37 - 输入错误n 请 沈阳工程学院课程设计报告 第4章 系统功能实现 try { con=nection(url); sql=Statement(); rs=eQuery("SELECT goodsnum,count(goodsnum) FROM information where listnum="+num+" group by goodsnum"); while(()) { con1=nection(url); sql1=Statement(); String number=ing(1); countBG=(2); n(countBG+number+name+time+price+add); rs1=eQuery("SELECT * FROM goods where num='"+number+"'"); while (()) { name=ing(2); price=(3); time=ing(4); add=ing(5); (" "+num+" "+number+" "+name+" "+price+" "+time+" "+add+" "+countBG+"n"); } (); } (); } catch (SQLException g) {n(g); } //{ // t(" "); // num=null;name=null;price=0;time=null;add=null; // ssageDialog(this," 输入错误n 请重新输入","提示",G_MESSAGE); // } } } } - 38 - 沈阳工程学院课程设计报告 第4章 系统功能实现 总 结 经过了两个星期的努力,在老师的大力支持和帮助下,我小组在规定时间内完成了此次课程设计的任务“小型超市管理系统”。 通过此次课程设计,使我们摆脱了单纯理论知识的学习状态,和实际的结合锻炼了我们解决实际设计中遇到问题的能力,也更加深了我们对所学的基础知识的掌握,深深地体会到了课程设计对理论知识促进与提高和对实践的具体应用。 选择设计题目很关键,小组人员共同研究讨论,最终确定了小型超市管理系统。之后在收集资料过程中,我们上网下载,并去了几家超市进行实地的考察,对超市的管理进行了需求分析,资料众多而且复杂,但我们克服了。 从最开始的不适应到将程序顺利的完成,是需要我们付出努力的,同时要有百折不挠的精神。这期间让我们懂得了许多在课堂上学不懂,学不透的知识,同时让我们感受到知识的重要性。开始时我们处于对很多相关知识不是很熟悉甚至不知道的状态,我们便开始研究和查看大量的相关资料和书籍,让自己头脑中模糊的概念逐渐清晰,使自己的作品一步步完善起来,每一次改进都是我们学习的收获。从中我们也充分认识到了面向对象Java程序设计给我们的学习带来了很大的帮助,也让我们学到了很多团结合作的经验,也锻炼了我们的整体思维的能力。有的时候把自己的新想法与他人分享,大家往往会提出置疑,但也就是在这种争论中才使我们的想法不断的提高、成熟。 通过对整体的设计,对局部的取舍,以及对细节的斟酌处理,都使我们的能力得到了锻炼,经验得到了丰富,并且意志品质力、抗压能力以及耐力也都得到了不同程度的提升,我想这就是我们课程设计要达到的目的。 经过长时间的艰辛努力最终换来了丰硕的成果,虽然有些不完善的地方,但毕竟是我们小组成员花费大量的时间设计出来的,也感到有一丝的欣慰。可以肯定地说现在的我们对程序设计这一块也有了一定的了解,但我们深知我们所了解的不过仅仅是皮毛而已,离真正的运用自如还相距甚远。 学无止境,学习生活无穷尽,只有掌握更多的、更新的知识才能使自己始终立于不败之地。如果只为现在所取得的成绩而沉浸于喜悦、骄傲之中的话,那么,我们就不会前进,只能停留在原来的地方踏步,甚至还会倒退。所以从毕业设计所暴露出的问题入手,不断努力完善自己,哪里欠缺,哪里补足。 - 39 - 沈阳工程学院课程设计报告 致谢 致 谢 本次课程设计的选题、设计方法及报告的撰写均是在我们的指导教师的细心指导下进行的。设计中离不开老师细心的帮助,没有老师的细心指导,就没有我们的设计成果。老师在面向对象设计方面有很多的实践经验,使得我们在设计时遇到的困难都能够迎刃而解,在我们面对问题的时候对我们虚心的指导和帮助及其严谨的工作态度、创新的精神,都使我们受益匪浅,在此特别向老师表示深深的感谢和由衷的敬意。 在这次的设计中,我们小组遇到了一部分的困难,但是不放弃的精神使得我们并没有灰心,在经过了大家的共同努力之后,我们的系统终于得到了完善。在此也要对帮助过我们的同学表示感谢,你们的帮助让我们的思路受到了启示,有了更大的发挥空间,让我们遇到困难的数量降到最低。 还要感谢的是我们小组内所有成员的团结协作的精神,正是因为有了团队意识,我们才能不畏惧困难,奋勇向前,进而圆满的完成了本次课程设计的任务。 另外,还要感谢学校给我们提供了此次课程设计的机会,不仅使我们所学的知识得以应用到实际中,也使我们开阔了视野,拓宽了思路,增长了学识,而且为我们今后的工作和学习打下了牢固的基础,也使增强我们对计算机的兴趣。 在此次课程设计中所学到的在以后的学习,工作,乃至生活上都将是我们宝贵的财富。我们以后会记住这两周的一点一滴的汗水和欢笑,会记住给予我们帮助的老师和同学们。最后,再一次衷心的感谢给予我们的帮助与支持的老师和同学们,谢谢你们! - 40 - 沈阳工程学院课程设计报告 参考文献 参考文献 [1] 耿祥义,张跃平.Java2实用教程(第三版).北京:清华大学出版社..2006. [2] 张小波,曾锡山.Java程序设计实训教程.冶金工业出版社.2006. [3] 孙一林,彭波.Java数据库编程实例.北京:清华大学出版社.2003. [4] 严桂兰,刘甲耀,刘波.Java编程模式与范例.机械工业出版社.2002. [5] 朱仲杰.Java全方位学习.机械工业出版社.2006. [6] 张思民.Java程序设计实践教程.北京:清华大学出版社.2006. [7] 汤一平.Java 语言程序设计.北京:科学出版社.2006. [8] 刘艺.Java 程序设计大学教程.北京:机械工业出版社.2006. - 41 -
版权声明:本文标题:Java超市管理系统 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.freenas.com.cn/jishu/1705126552h473832.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论