仓库管理系统(数据库)_第1页
仓库管理系统(数据库)_第2页
仓库管理系统(数据库)_第3页
仓库管理系统(数据库)_第4页
仓库管理系统(数据库)_第5页
已阅读5页,还剩54页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、电子与信息工程学院课程设计报告2018-2019学年第二学期)课程:面向对象程序设计软件工程实践(数据库设计与开发)题目:企业仓库管理系统专业班级:组另I:小组成员:指导教师:完成周数:2019年7月10日第一章引言1.1系统开发的背景随着计算机的发展,生活中仅仅依靠人工管理商场里面大量的的商品会浪费大部分的人力物力,还会造成较高的人工失误,所以有必要开发一个商场库存管理系统来很大程度上减少失误和不必要的浪费。实现信息数字化管理,提高管理效率,降低经营成本。利用商场库存管理系统可以提高商场的运营,提高总体效率系统开发的意义与目的仓库在现实生活中用途十分广泛,各种商城、超市要利用仓库存放物资,药

2、房、医院等要利用仓库存放药品,企业、工厂等要利用仓库存放原材料、生产成品,因此仓库的管理成了一项十分重要的工作。人工管理仓库既费时又费力,而且容易造成混乱,严重时会影响商城、企业的正常运作,造成恶劣的后果。随着计算机技术的发展,如何快速,高效,便捷的管理仓库受到了高度的关注。本系统模拟仓库管理,系统主要针对于日常库存信息的管理,包括物资管理、仓库管理、入库操作、入库査询统计、出库操作、出库查询统计、库存查询统计等处理情況。用户可以通过相应的模块,对仓库里的物品的基本情况和库存数量进行查询,管理员通过简单的操作即可轻松的管理仓库,查询各项相关信息,并能进行入库和出库操作等。通过仓库管理系统的设计

3、与实现,使我们巩固和加深对数据库基础理论和基本知识的理解,进一步掌握了使用数据库进行软件设计的基本思想和方法,提高了运用数据库理论解决实际问题的能力,锻炼了实际动手能力、创新能力,培养了调查研究、查阅技术文献、资料、手册以及编写文档的能力。开发工具简介1.3.1数据库系统SQLServers012:作为新一代的数据平台产品,SQLServer2012不仅延续现有数据平台的强大能力,全面支持云技术与平台,并且能够快速构建相应的解决方案实现私有云与公有云之间数据的扩展与应用的迁移。SQLServer2012提供对企业基础架构最高级别的支持一专门针对关键业务应用的多种功能与解决方案可以提供最高级别的

4、可用性及性能。在业界领先的商业智能领域,SQLServer2012提供了更多更全面的功能以满足不同人群对数据以及信息的需求,包括支持来自于不同网络环境的数据的交互,全面的自助分析等创新功能。针对大数据以及数据仓库,SQLServer2012提供从数TB到数百TB全面端到端的解决方案。作为微软的信息平台解决方案,SQLServer2012的发布,可以帮助数以千计的企业用户突破性地快速实现各种数据体验,完全释放对企业的洞察力。SQLServer2012包含企业版(Enterprise)、标准版(Standard),另外新增了商业智能版(BusinessIntelligence)。微软表示,SQLS

5、erver2012发布时还将包括Web版、开发者版本以及精简版。132程序编写语言:JAVAJAVA是一门面向对象编程语言,不仅吸收了C+语言的各种优点,还摒弃了C+里难以理解的多继承、指针等概念,因此JAVA语言具有功能强大和简单易用两个特征。JAVA语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。JAVA具有简单性、面向对象、分布式、健壮性、安全性、平台独立与可移植性、多线程、动态性等特点。JAVA可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序等。133集成开发环境:Eclipse:Eclipse是一个开放源代码

6、的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse附带了一个标准的插件集,包括Java开发工具(JavaDevelopmentTools,JDT)。Eclipse是著名的跨平台的自由集成开发环境(IDE)。最初主要用来Java语言开发,但是目前亦有人通过插件使其作为其他计算机语言比如C+和Python的开发工具。Eclipse的本身只是一个框架平台,但是众多插件的支持使得Eclipse拥有其他功能相对固定的IDE软件很难具有的灵活性。许多软件开发商以Eclipse为框架开发自己的IDE1.3.4操作系统Windows

7、10:Windows10是美国微软公司研发的跨平台及设备应用的操作系统。是微软发布的最后一个独立Windows版本。2014年10月1日,微软在新品发布会上,对外展示了该系统。2015年7月29日,微软发布Windows10正式版。Windows10共有7个发行版本,分别面向不同用户和设备。截止至2018年5月9日,Windows10正式版已更新至春季创意者10.0.17134.48版本,预览版已更新至秋季创意者10.0.17666版本。1.4开发计划35周:完成数据库需求分析58周:完成E-R图等概念模式89周:完成数据库模块分类910周:完成数据库基本程序编写1113周:数据库的实施阶段(

8、建立数据库,数据表,设置完整性,添加数据,建立视图,索引)1316周:完成数据库维护和前台连接17周:参加答辩人员分工:需求分析,概念模式,模块分类,E-R图绘制,java子界面由xx完成。查找资料,程序编写,数据库修改和添加信息,java的主界面由xx完成。数据流图,数据字典,数据库维护和前台连接由两人共同完成。第二章系统的需求及其基本功能用户需求分析仓库管理员:使用系统对仓库进行管理,进行商品的更新以及增、删、改、查等操作。客户:使用系统提交订单购买产品。生产车间:使用系统向仓库提交成品单和废料单,接收仓库的原料单处理对象分析系统要处理的对象包括员工基本信息、客户基本信息、仓库基本信息、产

9、品基本信息、库存基本信息、出入库基本信息六个方面,各个对象包含信息如下:员工基本信息:员工编号、员工户姓名、员工类型、联系电话、居住地址、入职时间、薪水,方便人员调动和工作分配。客户基本信息:客户姓名、客户性别、客户编号、客户类型、联系人、联系电话、通信地址,熟知客户信息,更好服务,同时方便管理仓库基本信息:仓库编号、仓库名称、仓库位置、库存情况,方便管理者及时更新数据,以防空间浪费,堵塞。生产车间基本信息:生产车间编号、生产车间名称、生产车间位置、生产类型,对原料进行加工,把原料和产品的库存信息返回给仓库管理。原料基本信息:原料编号、原料名称、原料类型、参考价格、入库单价、入库数量,对原料进

10、行记录产品基本信息:产品编号、产品名称、产品规格、参考价格、数量上限、数量下限,生产日期、生产车间、对于各种信息详细记录、备份库存基本信息:存储编号、产品编号、仓库编号、产品入库单价、产品数量、生产日期、保质期,保证产品可以及时更新。出入库信息:出入库操作类型、出入库产品编号、生产日期、出入库产品单价、出入库产品数量、客户编号、仓库编号、操作人员、出入库日期、出入库标记。2.3功能需求分析对于一个库存管理系统,首先就是要对库存进行管理,对库存信息进行收集和统计,以使后日查验。在功能设计方使要符合行业的实际,充分考虑用户的水平,用最简使的操作方法实现需要的功能。对于一个管理信息系统来说,也应该有

11、必要的安全性,保证数据只被需要的人看到。根据该企业的具体情况,系统主要功能有:1、管理员管理:管理员的权限管理,管理员密码修改。2、基本信息维护:客户、产品、仓库以及生产车间的基本信息的增、删、改查。3、库存管理:出库、入库、库存信息的修改,库存信息的查询。数据流图禺皆信息销S信息mg单鞠出小单产品出扎阵搖者庄存也新疾存信息品产品出人库单st-ml奇辜T?醫豊巳二取库存信鼻1宦販瞎.宼1鼎4出几库毕数据字典2:61数据项:名称:员工|编号:Y01简述:唯一标识一个采购员另I名:employees类型:char取值含义:字母表示采购员,后三位为顺序排列的数字名称:仓库编号:SR011简述:唯一标

12、识一个仓库另I名:warehouse类型:char取值含义:第一位表示仓库,后三位为顺序排列的数字名称:生产车间编号:WK01简述:唯一标识一个生产车间另I名:workshop类型:char取值含义:第一位表示生产车间,中间三位为顺序排列的数字。名称:原料编号:RM01简述:唯一标识一个原料另I名:material类型:char取值含义:第一位表示原料,字中间一位表示零件种类,后三位为顺序排列的数名称:产品编号:P01简述:唯一标识一个产品别名:product类型:char取值含义:第一位表示产品,中间一位表示产品种类,后三位为顺序排列的数字名称:客户编号:C01简述:唯一标识一个客户另I名:

13、customer类型:char取值含义:第一位表示客户,后三位为顺序排列的数字262数据结构名称:员工信息表编号:Y01简述:包含所有员工的基本信息组成:员工编号+员工姓名+员工类型+联系电话+居住地址+入职时间+薪水名称:仓库信息表编号:SR01简述:包含所有仓库的基本信息组成:仓库编号+仓库名称+仓库位置+库存情况+存储上限名称:生产车间信息表编号:WK01简述:包含所有生产车间的基本信息组成:生产车间编号+生产车间名称+生产车间位置+生产类型名称:原料信息表编号:LA001简述:包含所有原料的基本信息组成:原料编号+原料名称+原料类型+参考价格+入库单价+入库数量名称:产品信息表编号:P

14、01简述:包含所有求购信息组成:产品编号+产品名称+产品规格+参考价格+数量上限+数量下限+生产日期+生产车间名称:客户信息表编号:C01简述:包含所有客户的信息组成:客户姓名+客户性别+客户编号+客户类型+联系人+联系电话+通信地址2.6.3数据流:编号L1名称原料采购入库简述采购员提交采购单来源米购员去向原料入库表组成员工编号+原料编号+价格+数量编号L2名称原料出库简述向车间输送原料来源仓库去向:原料出口表组成:原料编号+价格+数量编号L3名称产品入库简述产生的产品入库来源车间去向产品入库表组成产品编号+价格+数量编号L4名称购买订单简述提交购买的信息来源顾客去向产品出库表组成产品编号+

15、价格+数量编号L5名称产品出库简述向顾客发送产品来源仓库去向产品出库表组成产品编号+价格+数量2.6.4处理逻辑:编号:A001名称:原料出入库管理简述:员工以及生产车间向仓库提供原料出入库的数据输入的数据流:原料出入库单处理:系统通过员工以及生产车间提供的数据进行处理输出的数据流:原料出入库报表处理频率:一天一次编号:A002名称:产品出入库管理简述:生产车间以及销售要根据自己的产品及销售提供可供清单输入的数据流:产品出入库单处理:系统通过顾生产车间以及销售提供的数据进行处理输出的数据流:产品出入报表处理频率:一周一次编号:A003名称:销售管理简述:系统通过信息汇总对销量进行统计输入的数据

16、流:销售信息处理:系统对销量进行统计形成销售报表输出的数据流:销售统计处理频率:一月一次2.6.5数据存储:编号:C1名称:原料出入库简述:记录原料的名称、单价、库存数量等信息组成:原料+数量+单价+出库/入库编号C2名称产品出入库简述记录产品的产量、售出、退回组成产品+数量+单价+出库/入库编号C3名称员工信息简述记录员工的基本信息组成员工编号+姓名+年龄+性别+职位+薪资编号C4名称客户信息简述记录客户的基本信息组成客户编号+姓名+年龄+性别+会员级别编号C5名称车间信息简述记录车间的基本信息组成车间编号+名称+位置+生产类型编号C6名称仓库信息简述记录仓库的基本信息组成仓库编号+名称+位

17、置+库存情况名称:原料信息简述:记录原料的基本信息组成:原料编号+名称+类型+价格+单价+数量编号C8名称产品信息简述记录产品的基本信息组成产品编号+名称+类型+价格+单价+数量+规格第三章总体设计方案系统功能框架图第四章数据库设计概念结构设计4.1.1原料出入库ER模型图图哄给生产车麻mnm产品住rag;铸竇您嘩丽姿復律位赛-、一厂了L二/ST盪弐膨c售董、窣击秽客启7逻辑结构设计4.2.1将E-R图转换为关系模型“员工”,“原料”,“车间”的模式转换员工车闫其关系模式设计如下:员工关系模式(员工编号,类型,年龄,性别,姓名,联系方式,入职时间,薪水)原料关系模式(原料编号,名称,类型,参考

18、价格,数量上限,入库数量,生产车间)车间关系模式(仓库编号,名称,地址,仓库情况)原料入库关系模式(原料编号,车间编号,数量,价格)“车间”,“产品”,“客户”的模式转换种类客户姓名客户性别-车间编号客户.运行状态.车间地址生产车间-客户类型产品编号生产车间产品客户编号.负责人员.联系电话.其关系模式设计如下:车间关系模式(车间编号,名称,地址,类型)产品关系模式(产品编号,产品名称,种类,出库价格,生产时间,生产车间)产品出库关系模式(生产车间编号,产品编号,客户编号)物理结构设计索引弋索引属性-NonClusteredlndex-20130708-103401X弋索引属性-NonClust

19、eredlndex-20130708-103401X&就绪选偉页空常规于选顷卡筛选器空碎片却扩展属性赳localhostsa索引类型凶:唯一音看洼接属件就绪盍引艇列包含性列名称排序IW数据类型大小标识NULL11添抑(臥“CKPR升序smallint2否昱删除(R)复脚本迅帘助表名CD:P索引名称M):NonClusteredlndex-20190708-103401选择贡百选顷丰存储?讳选器空碎片更脚本址帮助兀索引属性-NonClusteredlndex-20190708103519仆就绪表名币:RM索引名椒M):NonClusteredlndex-20190708103519壷引类型X):

20、连接赳lotalhostsa非聚集唯一Q奇看洋覆属件就绪索引维列包含性列名排序顺序数据类型丈小标识允许NULL值沥加(町“CKPWsmallint2否否删除冈*索弓瞩性-NonClusteredlndex-20190708-103720-X岀常规宫选项序存储严端选器予碎片上扩展属性连接粉localhost血曹看连度囲性进廈就绪索引從列包含性列6排序顺序数据类型大小标识允许NULL请添加(A).5A3-序rKhcirfS)16否否竝除R)S(T):Y索引名称限:NonCIusteredIndex-?0190708-103720索引类型氏);非聚笑唯一确走取消帮助4.3.2视图第五章数据库实施5.

21、1数据库的建立usemastergoIFEXISTS(SELECT*FROMsysdatabasesWHEREname=CKGL)DROPDATABASECKGLCREATEDATABASECKGLon(NAME=CKGL,FILENAME=D:DATA1CKGL.mdf,SIZE=5,FILEGROWTH=1)LOGON(NAME=JXGL_log,FILENAME=D:DATA1CKGL_log.ldf,SIZE=2,MAXSIZE=20,FILEGROWTH=10%)GO5.2表的建立5.2.1客户表的建立USECKGLGOCREATETABLEC(CNONCHAR(3)NOTNULL-

22、编号CONSTRAINTPK_CNOPRIMARYKEYCLUSTERED,CHECK(CNOLIKEC0-90-9),-检查约束CNAMENCHAR(8)NOTNULL,-名称sexnchar(1)notnull,POSTNCHAR(6)NOTNULL,-客户类型YNONCHAR(3)NOTNULL,-交易员工FOREIGNKEY(YNO)REFERENCESY(YNO),-外键约束PHONEUMBERNCHAR(12)NOTNULL,-电话HOMENCHAR(6)NOTNULL,-居住地PNONCHAR(3)NOTNULL,FOREIGNKEY(PNO)REFERENCESP(PNO),)

23、5.2.2产品表USECKGLGOCREATETABLEP(PNONCHAR(3)NOTNULL-编号CONSTRAINTPK_PNOPRIMARYKEYCLUSTERED,CHECK(PNOLIKEP0-90-9),PNAMENCHAR(8)NOTNULL,-名称POSTNCHAR(6)NOTNULL,-规格CKPRICESMALLINTNULL,-参考价格PTIMENCHAR(12)NOTNULL,-生产日期WKNONCHAR(4)NOTNULL,-生产车间FOREIGNKEY(WKNO)REFERENCESWK(WKNO),)CONSTRAINTPK_SNOPRIMARYKEYCLUST

24、ERED5.2.3员工表USECKGLGOCREATETABLEY(YNONCHAR(3)NOTNULLCHECK(YNOLIKEY0-90-9),YNAMENCHAR(8)NOTNULL,SEXCHAR(1)NULL,INTIMENCHAR(12)NOTNULL,POSTNCHAR(5)NULL,HOMENCHAR(15)NULL,SALARYNCHAR(8)NOTnull,-编号号字段,非空约束-主键约束-检查约束-姓名字段,非空约束-性别字段-入职时间字段-职务字段-居住地-薪水PHONENUMBERNCHAR(15)NOTnull,-联系电话)5.2.4原料表USECKGLGOCREA

25、TETABLERM(RMNONCHAR(4)NOTNULL-编号CONSTRAINTPK_RMNOPRIMARYKEYCLUSTERED,CHECK(RMNOLIKERM0-90-9),RMNAMENCHAR(8)NOTNULL,-名称POSTNCHAR(6)NOTNULL,-类型CKPRICESMALLINTNOTNULL,-参考价格INPRICESMALLINTNOTNULL,-入库价格INNUMBERSMALLINTNOTNULL,-入库数量SRNONCHAR(4)NOTNULL,-管理仓库FOREIGNKEY(SRNO)REFERENCESSR(SRNO),)5.2.5仓库表USECK

26、GLGOCREATETABLESR(SRNONCHAR(4)NOTNULL-编号CONSTRAINTPK_SRNOPRIMARYKEYCLUSTERED,CHECK(SRNOLIKESR0-90-9),-检查约束SRNAMENCHAR(20)NOTNULL,-名称HOMENCHAR(20)NOTNULL,-位置STANCHAR(30)NOTNULL,-库存情况)5.2.6车间表USECKGLGOCREATETABLEWK(WKNONCHAR(4)NOTNULL-编号CONSTRAINTPK_WKNOPRIMARYKEYCLUSTERED,CHECK(WKNOLIKEWK0-90-9),WKNA

27、MENCHAR(8)NOTNULL,-名称HOMENCHAR(15)NOTNULL,-位置STAMODENCHAR(12)NOTNULL,-运行状态)表间关系图第六章详细设计与实现1.Java1.1登录界面设计1.1.1实验代码packageStart;importjava.awt.*;importjavax.swing.*;importsrc.index;importjava.awt.event.*;publicclassStartextendsJFrameJPanelpn1,pn2,pn3;JButtonbt1,bt2;JLabellb1,lb2;JTextFieldnameTextFie

28、ld;JPasswordFieldpwdPasswordField;publicStart()super();pn1=newJPanel();pn2=newJPanel();pn3=newJPanel();lbl=newJLabel(用户名”);lb2=newJLabel(密码”);bt1=newJButton(”登录”);bt2=newJButton(”取消”);nameTextField=newJTextField(10);pwdPasswordField=newJPasswordField(10);Init();voidInit()this.setLayout(newGridLayout

29、(3,1);pn1.add(lb1);pn1.add(nameTextField);pn2.add(lb2);pn2.add(pwdPasswordField);pn3.add(bt1);pn3.add(bt2);this.add(pn1);this.add(pn2);this.add(pn3);this.setTitle(”登录”);this.setSize(230,150);this.setLocation(650,300);this.setResizable(false);this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);this.s

30、etVisible(true);bt2.addActionListener(newbt2Clicked(this);bt1.addActionListener(newbt1Clicked(this);nameTextField.setText(zxc);pwdPasswordField.setText(123);nameTextField.addMouseListener(newUserNameListener(this);publicJTextFieldgetNameTextField()returnnameTextField;publicJPasswordFieldgetPasswordF

31、ield()returnpwdPasswordField;classUserNameListenerextendsMouseAdapterprivateStartlogin;publicUserNameListener(Startl)login=l;publicvoidmouseClicked(MouseEvente)this.login.getNameTextField().setText();classbt2ClickedimplementsActionListenerprivateStartlogin;publicbt2Clicked(Startl)login=l;Overridepub

32、licvoidactionPerformed(ActionEvente)login.dispose();classbt1ClickedimplementsActionListenerprivateStartlogin;publicbt1Clicked(Startl)login=l;OverridepublicvoidactionPerformed(ActionEvente)StringuserName=login.getNameTextField().getText().trim();StringuserPwd=newString(login.getPasswordField().getPas

33、sword().trim();if(userName.equals(zxc)&userPwd.contentEquals(123)JOptionPane.showMessageDialog(null,欢迎使用本系统,使用者:+userName,登陆成功,JOptionPane.INFORMATION_MESSAGE);indexi=newindex();return;JOptionPane.showConfirmDialog(null,用户名或密码错误,登录失败,JOptionPane.WARNING_MESSAGE);publicstaticvoidmain(Stringaargs)newS

34、tart();1.1.2界面展示用户呂5登陆物X密码1.2主界面设计1.2.1实验代码packagesrc;importjava.awt.*;importjava.awt.event.ActionEvent;importjava.awt.event.ActionListener;importjavax.swing.*;importjavax.swing.table.TableModel;publicclassindexextendsJFrameimplementsActionListenerJPanelpn1,pn2,pn3;/面板JLabellabel;JButtonbt1,bt2,bt3,

35、bt4,bt5,bt6,bt7,bt8;/按钮JTabletable;JScrollPanescrollPane;publicindex()super();pn1=newJPanel();pn2=newJPanel();label=newJLabel(查看表中信息:”);btl=newJButton(”员工”);bt1.addActionListener(this);bt1.setActionCommand(y);bt2=newJButton(”客户”);bt2.addActionListener(this);bt2.setActionCommand(k);bt3=newJButton(”原料

36、”);bt3.addActionListener(this);bt3.setActionCommand(l);bt4=newJButton(”产品”);bt4.addActionListener(this);bt4.setActionCommand(c);bt5=newJButton(”仓库”);bt5.addActionListener(this);bt5.setActionCommand(p);bt6=newJButton(”车间”);bt6.addActionListener(this);bt6.setActionCommand(j);pn1.add(label);pn1.add(bt1

37、);pn1.add(bt2);pn1.add(bt3);pn1.add(bt4);pn1.add(bt5);pn1.add(bt6);table=newJTable();scrollPane=newJScrollPane(table);this.add(pn1,North);this.add(scrollPane);this.setTitle(CKGL系统“);this.setSize(800,500);this.setLocation(400,200);this.setResizable(true);this.setDefaultCloseOperation(JFrame.EXIT_ON_C

38、LOSE);this.setVisible(true);OverridepublicvoidactionPerformed(ActionEvente)if(e.getActionCommand().equals(y)newYStoreManager();elseif(e.getActionCommand().equals(k)newCManager();elseif(e.getActionCommand().equals(l)newRManager();elseif(e.getActionCommand().equals(c)newPManager();elseif(e.getActionCo

39、mmand().equals(p)newSRManager();elseif(e.getActionCommand().equals(j)newWKManager();1.2.2界面展示1.2功能模块设计1.2.1类的定义(以客户为例)CAdd.javaCAlter.javaCManger.javaCTable.java客户信息添加类客户信息修改类客户信息调用以及删除类客户信息界面类SeqTest.java数据库连接1.2.2类的主要方法(以客户为例)CAdd()进按钮等对象的添加addActionListener()事件监听类setActionCommend()给一个JButton设置一个属

40、性的字符串值SetLayout()设置布局SetSize()设置组件的长度和宽度SetLocation()设置组件的定位SetString()封装1.2.3主要代码(以客户为例)客户的信息添加packagesrc;importjavax.swing.JDialog;importjavax.swing.JFrame;importjava.awt.*;importjava.awt.event.*;importjava.sql.*;importjava.util.*;importjavax.swing.*;classCAddextendsJDialogimplementsActionListener

41、JLabellb1,lb2,lb3,lb4,lb5,lb6,lb7,lb8;JTextFieldtf1,tf2,tf3,tf4,tf5,tf6,tf7,tf8;JButtonbt1,bt2;JPanelpn1,pn2,pn3,pn4,pn5,pn6,pn7,pn8;publicCAdd(Frameowner,Stringtitle,Booleanmodal)super(owner,title,modal);/JDialog的带参构造,父窗口、窗口标题、是否能移动TOC o 1-5 h zlb1=newJLabel(编号);lb2=newJLabel(姓名);lb3=newJLabel(性别);

42、lb4=newJLabel(类别);lb5=newJLabel(负责人员);lb6=newJLabel(电话号码);lb7=newJLabel(联系地址);lb8=newJLabel(仓库编号);tf1=newJTextField(8);tf2=newJTextField(8);tf3=newJTextField(8);tf4=newJTextField(8);tf5=newJTextField(8);tf6=newJTextField(8);tf7=newJTextField(8);tf8=newJTextField(8);btl=newJButton(”添加”);bt1.addAction

43、Listener(this);btl.setActionCommand(add);设置按钮名称bt2=newJButton(取消”);bt2.addActionListener(this);bt2.setActionCommand(cancel);设置按钮名称pn1=newJPanel();pn2=newJPanel();pn3=newJPanel();pn4=newJPanel();pn5=newJPanel();pn6=newJPanel();pn7=newJPanel();pn8=newJPanel();pn1.setLayout(newGridLayout(8,1);pn2.setLa

44、yout(newGridLayout(8,1);pn1.add(lb1);pn1.add(lb2);pn1.add(lb3);pn1.add(lb4);pn1.add(lb5);pn1.add(lb6);pn1.add(lb7);pn1.add(lb8);pn2.add(tf1);pn2.add(tf2);pn2.add(tf3);pn2.add(tf4);pn2.add(tf5);pn2.add(tf6);pn2.add(tf7);pn2.add(tf8);pn3.add(bt1);pn3.add(bt2);this.add(pn1,BorderLayout.WEST);this.add(p

45、n2);this.add(pn3,BorderLayout.SOUTH);this.add(pn4,BorderLayout.EAST);this.add(pn5,BorderLayout.NORTH);this.add(pn6,BorderLayout.NORTH);this.add(pn7,BorderLayout.NORTH);this.add(pn8,BorderLayout.NORTH);this.setSize(370,270);this.setLocation(401,281);this.setResizable(false);this.setVisible(true);publ

46、icvoidactionPerformed(ActionEvente)if(e.getActionCommand().equals(add)按下添加按钮连接数据库并插入记录PreparedStatementps=null;Connectionct=null;ResultSetrs=null;Stringurl=jdbc:sqlserver:/localhost:1433;DatabaseName=CKGL;tryct=DriverManager.getConnection(url,sa,sa);Strings=(insertintoCvalues(?,?,?,?,?,?,?,?);ps=ct.

47、prepareStatement(s);ps.setString(1,tf1.getText();ps.setString(2,tf2.getText();ps.setString(3,tf3.getText();ps.setString(4,tf4.getText();ps.setString(5,tf5.getText();ps.setString(6,tf6.getText();ps.setString(7,tf7.getText();ps.setString(8,tf8.getText();ps.executeUpdate();this.dispose();catch(Exceptio

48、ne2)finallytryif(rs!=null)rs.close();if(ps!=null)ps.close();if(ct!=null)ct.close();catch(Exceptione3)elseif(e.getActionCommand().equals(cancel)this.dispose();客户的信息修改packagesrc;importjava.awt.*;importjava.awt.event.*;importjava.sql.*;importjava.util.*;importjavax.swing.*;classCAlterextendsJDialogimpl

49、ementsActionListenerJLabellb1,lb2,lb3,lb4,lb5,lb6,lb7,lb8;JTextFieldtf1,tf2,tf3,tf4,tf5,tf6,tf7,tf8;JButtonbt1,bt2;JPanelpn1,pn2,pn3,pn4,pn5,pn6,pn7,pn8;publicCAlter(Frameowner,Stringtitle,Booleanmodal,CTabletable,introw)super(owner,title,modal);lb1=newJLabel(lb2=newJLabel(lb3=newJLabel(lb4=newJLabe

50、l(lb5=newJLabel(lb6=newJLabel(lb7=newJLabel(lb8=newJLabel(编号);姓名);性别);类别);负责人员);电话号码);联系住址);仓库编号);tf1=newJTextField(8);tfl.setText(String)table.getValueAt(row,0);/获得指定行、第一列的单元格值SNOtfl.setEditable(false);/设置为不可修改tf2=newJTextField(8);tf2.setText(String)table.getValueAt(row,l);/获得指定行、第二列的单元格值SNAMEtf3=n

51、ewJTextField(8);tf3.setText(String)table.getValueAt(row,2);/获得指定行、第三列的单元格值SEXtf4=newJTextField(8);tf4.setText(String)table.getValueAt(row,3).toString();获得指定行第四列的单元格值,即AGE字段的值要转成字符串类型tf5=newJTextField(8);tf5.setText(String)table.getValueAt(row,4);/获得指定行、第五列的单元格值,COLLEGEtf6=newJTextField(8);tf6.setTex

52、t(String)table.getValueAt(row,5);tf7=newJTextField(8);tf7.setText(String)table.getValueAt(row,6);tf8=newJTextField(8);tf8.setText(String)table.getValueAt(row,7);btl=newJButton(”修改”);bt1.addActionListener(this);pn3=newJPanel();pn6=newJPanel();bt1.setActionCommand(edit);bt2=newJButton(”取消”);bt2.addAct

53、ionListener(this);bt2.setActionCommand(cancel);pn1=newJPanel();pn2=newJPanel();pn4=newJPanel();pn5=newJPanel();pn7=newJPanel();pn8=newJPanel();pn1.setLayout(newGridLayout(8,1);pn2.setLayout(newGridLayout(8,1);pn1.add(lb1);pn1.add(lb2);pn1.add(lb3);pn1.add(lb4);pn1.add(lb5);pn1.add(lb6);pn1.add(lb7);

54、pn1.add(lb8);pn2.add(tf1);pn2.add(tf2);pn2.add(tf3);pn2.add(tf4);pn2.add(tf5);pn2.add(tf6);pn2.add(tf7);pn2.add(tf8);pn2.add(tf1);pn2.add(tf2);pn2.add(tf3);pn2.add(tf4);pn2.add(tf5);pn2.add(tf6);pn2.add(tf7);pn2.add(tf8);pn3.add(bt1);pn3.add(bt2);this.add(pn1,BorderLayout.WEST);this.add(pn2);this.ad

55、d(pn3,BorderLayout.SOUTH);this.add(pn4,BorderLayout.EAST);this.add(pn5,BorderLayout.NORTH);this.add(pn6,BorderLayout.NORTH);this.add(pn7,BorderLayout.NORTH);this.add(pn8,BorderLayout.NORTH);this.setSize(370,270);this.setLocation(401,281);this.setResizable(false);this.setVisible(true);publicvoidactio

56、nPerformed(ActionEvente)if(e.getActionCommand().equals(edit)PreparedStatementps=null;Connectionct=null;ResultSetrs=null;Stringurl=jdbc:sqlserver:/localhost:1433;DatabaseName=CKGL;tryct=DriverManager.getConnection(url,sa,sa);Stringss=(updateCsetCNAME=?,sex=?,POST=?,YNO=?,PHONEUMBER=?,HOME=?,PNO=?wher

57、eCNO=?);ps=ct.prepareStatement(ss);ps.setString(1,tf2.getText();ps.setString(2,tf3.getText();ps.setString(3,tf4.getText();ps.setString(4,tf5.getText();ps.setString(5,tf6.getText();ps.setString(6,tf7.getText();ps.setString(7,tf8.getText();ps.setString(8,tf1.getText();ps.executeUpdate();this.dispose()

58、;catch(Exceptione2)finallytryif(rs!=null)rs.close();if(ps!=null)ps.close();if(ct!=null)ct.close();catch(Exceptione3)elseif(e.getActionCommand().equals(cancel)this.dispose();客户的界面packagesrc;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.PreparedStatement;importjava.sql.ResultSe

59、t;importjava.util.ArrayList;importjavax.swing.table.*;/CTable类主要用于客户C的表格方式显示/AbstractTableModel抽象类主要把数据库中的信息以表格形式显式classCTableextendsAbstractTableModelArrayListheadings,records;/可变长的数组PreparedStatementps=null;Connectionct=null;ResultSetrs=null;publicintgetRowCount()/获得表格的行数returnthis.records.size();

60、publicintgetColumnCount()/获得表格的列数returnthis.headings.size();publicObjectgetValueAt(introw,intcolumn)/获得指定行、指定列的单元格值return(ArrayList)this.records.get(row).get(column);publicStringgetColumnName(inte)/获得表格的列标题return(String)this.headings.get(e);publicCTable()/无参构造方法用于表中所有记录的查询this.handles(select*fromC);

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论