




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、18java程序设计java程序设计系专 业班 级08级嵌入式系统实验班学 号 26号姓 名 赵黎明题 目 学生成绩管理系统任课教师 彭洁 一、课程设计要求:1、用到书上(课本或实验册)上的至少三个实例;2、用到至少两种布局和至少四种组件;3、用到对话框;4、用到对数据库的查询、删除、添加和修改;5、最好用到输入输出流;6、具有一定的实际意义。二、用到的实例及实际意义:2.1 程序所用到的实例:1、java2使用教程第10章例题10.12 p282;2、java2使用教程第11章例题11.8 p323;3、java2使用教程第15章所有例题均有使用作参考 p391-411;4、在其他参考书和网
2、上也有用到相关程序和代码,并有所参考和借鉴。2.2程序的实际意义: 本学生成绩管理系统具有对学生成绩进行管理的功能。并于数据库相连接,能够对学生的成绩、姓名、出生日期进行查询、添加和删除等,简捷方便,容易使用。三、程序代码及运行效果:3.1.1 主类代码:/*主类代码*/import javax.swing.*;import java.awt.*;import java.awt.event.*;class mypanel extends jpanel image img=toolkit.getdefaulttoolkit().getimage(c:/a.jpg); public void pa
3、int(graphics g) g.drawimage(img,0,0,this); public class mainform extends jframe implements actionlistener jmenu msystem=new jmenu(系统); jmenuitem mexit=new jmenuitem(退出); jmenu moperate=new jmenu(数据操作); jmenuitem madd=new jmenuitem(添加); jmenuitem mdel=new jmenuitem(删除); jmenuitem mmodify=new jmenuite
4、m(修改); jmenu mquery=new jmenu(查询); jmenuitem mname=new jmenuitem(按姓名查询); jmenuitem mscore=new jmenuitem(按成绩查询); jmenu mhelp=new jmenu(帮助); jmenuitem mabout=new jmenuitem(软件信息); jmenubar mbar=new jmenubar(); mainform() super(学生成绩管理系统); setsize(875,583); msystem.add(mexit); moperate.add(madd); moperat
5、e.add(mdel); moperate.add(mmodify); mquery.add(mname); mquery.add(mscore); mhelp.add(mabout); mbar.add(msystem); mbar.add(moperate); mbar.add(mquery); mbar.add(mhelp); setjmenubar(mbar); mexit.addactionlistener(this); madd.addactionlistener(this); mdel.addactionlistener(this); mmodify.addactionliste
6、ner(this); mname.addactionlistener(this); mscore.addactionlistener(this); mabout.addactionlistener(this); setcontentpane(new mypanel(); setvisible(true); public void actionperformed(actionevent ae) if(ae.getsource()=mexit) system.exit(0); else if(ae.getsource()=mabout) joptionpane.showmessagedialog(
7、this,学生成绩管理系统nn应用科学学院nn2011年4月,软件信息,joptionpane.information_message); else if(ae.getsource()=madd) new addform().setvisible(true); else if(ae.getsource()=mdel) new deleteform().setvisible(true); else if(ae.getsource()=mmodify) new modifyform().setvisible(true); else if(ae.getsource()=mname) new name
8、queryform().setvisible(true); else if(ae.getsource()=mscore) new scorequeryform().setvisible(true); public static void main(string args) new mainform(); 3.1.2 运行效果:3.2.1 修改数据:/*修改数据*/import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;public class modifyform extends jfra
9、me implements actionlistener jlabel labname=new jlabel(姓名:); jlabel labdate=new jlabel(出生日期:); jlabel labscore=new jlabel(成绩:); jtextfield txtname=new jtextfield(20); jtextfield txtdate=new jtextfield(18); jtextfield txtscore=new jtextfield(20); jbutton btnmodify=new jbutton(修改); jbutton btncancel=n
10、ew jbutton(取消); jbutton btnquery=new jbutton(查询); jpanel pan=new jpanel(); jpanel pan1=new jpanel(); jpanel pan2=new jpanel(); jpanel pan3=new jpanel(); jpanel pan4=new jpanel(); connection con; statement sql; resultset rs; modifyform() super(修改数据); setsize(400,300); pan1.add(labname); pan1.add(txtn
11、ame); pan2.add(labdate); pan2.add(txtdate); pan3.add(labscore); pan3.add(txtscore); pan4.add(btnquery); pan4.add(btnmodify); pan4.add(btncancel); pan.setlayout(new gridlayout(3,1); pan.add(pan1); pan.add(pan2); pan.add(pan3); getcontentpane().add(pan,center); getcontentpane().add(pan4,south); btnque
12、ry.addactionlistener(this); btnmodify.addactionlistener(this); btncancel.addactionlistener(this); btnmodify.setenabled(false); txtdate.seteditable(false); txtscore.seteditable(false); setvisible(true); txtname.requestfocus(); public void actionperformed(actionevent ae) if(ae.getsource()=btncancel) d
13、ispose(); else if(ae.getsource()=btnquery) try class.forname(sun.jdbc.odbc.jdbcodbcdriver); catch(classnotfoundexception e) trycon=drivermanager.getconnection(jdbc:odbc:sun,gxy,123); sql=con.createstatement(); rs=sql.executequery(select * from 成绩表 where 姓名=+txtname.gettext()+); if(rs.next() txtname.
14、settext(rs.getstring(姓名); txtscore.settext(new integer(rs.getint(成绩).tostring(); txtdate.settext(rs.getdate(出生日期).tostring(); btnmodify.setenabled(true); txtdate.seteditable(true); txtscore.seteditable(true); else system.out.println(不存在该记录! ); btnmodify.setenabled(false); txtname.settext(); txtscore
15、.settext(); txtdate.settext(); txtdate.seteditable(false); txtscore.seteditable(false); catch(sqlexception e) else if(ae.getsource()=btnmodify) try system.out.println(update 成绩表 set 出生日期=+txtdate.gettext()+,成绩=+txtscore.gettext()+ where 姓名=+txtname.gettext()+); sql.executeupdate(update 成绩表 set 出生日期=
16、+txtdate.gettext()+,成绩=+txtscore.gettext()+ where 姓名=+txtname.gettext()+); system.out.println(记录修改完毕!); btnmodify.setenabled(false); txtname.settext(); txtscore.settext(); txtdate.settext(); txtdate.seteditable(false); txtscore.seteditable(false); con.close(); catch(sqlexception e) public static voi
17、d main(string args) new modifyform(); 3.2.2 运行效果:3.3.1 删除数据:/*删除数据*/import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;public class deleteform extends jframe implements actionlistenerjlabel labname=new jlabel(姓名:); jlabel labdate=new jlabel(出生日期:); jlabel labscore=new j
18、label(成绩:); jtextfield txtname=new jtextfield(20); jtextfield txtdate=new jtextfield(18); jtextfield txtscore=new jtextfield(20); jbutton btndelete=new jbutton(删除); jbutton btncancel=new jbutton(取消); jbutton btnquery=new jbutton(查询); jpanel pan=new jpanel(); jpanel pan1=new jpanel(); jpanel pan2=new
19、 jpanel(); jpanel pan3=new jpanel(); jpanel pan4=new jpanel(); connection con; statement sql; resultset rs; deleteform() super(删除数据); setsize(400,300); pan1.add(labname); pan1.add(txtname); pan2.add(labdate); pan2.add(txtdate); pan3.add(labscore); pan3.add(txtscore); pan4.add(btnquery); pan4.add(btn
20、delete); pan4.add(btncancel); pan.setlayout(new gridlayout(3,1); pan.add(pan1); pan.add(pan2); pan.add(pan3); getcontentpane().add(pan,center); getcontentpane().add(pan4,south); btnquery.addactionlistener(this); btndelete.addactionlistener(this); btncancel.addactionlistener(this); btndelete.setenabl
21、ed(false);/取消删除按钮的功能 txtdate.seteditable(false); txtscore.seteditable(false); setvisible(true); txtname.requestfocus(); public void actionperformed(actionevent ae) if(ae.getsource()=btncancel) dispose(); else if(ae.getsource()=btnquery)/实现查询功能 try class.forname(sun.jdbc.odbc.jdbcodbcdriver); catch(c
22、lassnotfoundexception e) trycon=drivermanager.getconnection(jdbc:odbc:sun,gxy,123); sql=con.createstatement(); rs=sql.executequery(select * from 成绩表 where 姓名=+txtname.gettext()+); if(rs.next() txtname.settext(rs.getstring(姓名); txtscore.settext(new integer(rs.getint(成绩).tostring(); txtdate.settext(rs
23、.getdate(出生日期).tostring(); btndelete.setenabled(true);/使删除按钮功能实现 txtdate.seteditable(true); txtscore.seteditable(true); else system.out.println(不存在该记录!); btndelete.setenabled(false); txtname.settext(); txtscore.settext(); txtdate.settext(); txtdate.seteditable(false); txtscore.seteditable(false); ca
24、tch(sqlexception e) else if(ae.getsource()=btndelete)/实现删除功能 try system.out.println(update 成绩表 set 出生日期=+txtdate.gettext()+,成绩=+txtscore.gettext()+ where 姓名=+txtname.gettext()+); sql.executeupdate(delete from 成绩表 where 姓名=+txtname.gettext()+); system.out.println(记录删除完毕!); btndelete.setenabled(false)
25、; txtname.settext(); txtscore.settext(); txtdate.settext(); txtdate.seteditable(false); txtscore.seteditable(false); con.close(); catch(sqlexception e) public static void main(string args) new deleteform(); 3.3.2 运行效果:3.4.1 添加数据:/*添加数据*/import javax.swing.*;import java.awt.*;import java.awt.event.*;
26、import java.sql.*;public class addform extends jframe implements actionlistenerjlabel labname=new jlabel(姓名:); jlabel labdate=new jlabel(出生日期:); jlabel labscore=new jlabel(成绩:); jtextfield txtname=new jtextfield(20); jtextfield txtdate=new jtextfield(18); jtextfield txtscore=new jtextfield(20); jbut
27、ton btnadd=new jbutton(添加); jbutton btncancel=new jbutton(取消); jpanel pan=new jpanel(); jpanel pan1=new jpanel(); jpanel pan2=new jpanel(); jpanel pan3=new jpanel(); jpanel pan4=new jpanel(); connection con; statement sql; resultset rs; addform() super(添加数据); setsize(400,300); pan1.add(labname); pan
28、1.add(txtname); pan2.add(labdate); pan2.add(txtdate); pan3.add(labscore); pan3.add(txtscore); pan4.add(btnadd); pan4.add(btncancel); pan.setlayout(new gridlayout(3,1); pan.add(pan1); pan.add(pan2); pan.add(pan3); getcontentpane().add(pan,center); getcontentpane().add(pan4,south); btnadd.addactionlis
29、tener(this); btncancel.addactionlistener(this); btnadd.setenabled(true); txtdate.seteditable(true); txtscore.seteditable(true); setvisible(true); txtname.requestfocus(); public void actionperformed(actionevent ae) string recode,insert1,出生日期,姓名; int 成绩; if(ae.getsource()=btncancel) this.dispose(); el
30、se if(ae.getsource()=btnadd) try class.forname(sun.jdbc.odbc.jdbcodbcdriver); catch(classnotfoundexception e) trycon=drivermanager.getconnection(jdbc:odbc:sun,gxy,123); sql=con.createstatement(); 姓名=txtname.gettext(); 出生日期=txtdate.gettext(); 成绩=integer.parseint(txtscore.gettext(); recode=(+姓名+,+出生日期
31、+,+成绩+); insert1=insert into 成绩表 values +recode; sql.executeupdate(insert1); system.out.println(记录添加完毕!); btnadd.setenabled(false); txtname.settext(); txtscore.settext(); txtdate.settext(); con.close(); catch(sqlexception e) public static void main(string args) new addform(); 3.4.2 运行效果:3.5.1 按姓名查询数
32、据:/*按姓名查询数据*/import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;public class namequeryform extends jframe implements actionlistener jlabel labname=new jlabel(姓名:); jlabel labdate=new jlabel(出生日期:); jlabel labscore=new jlabel(成绩:); jtextfield txtname=new jtextfield(20);
33、jtextfield txtdate=new jtextfield(18); jtextfield txtscore=new jtextfield(20); jbutton btncancel=new jbutton(取消); jbutton btnquery=new jbutton(查询); jpanel pan=new jpanel(); jpanel pan1=new jpanel(); jpanel pan2=new jpanel(); jpanel pan3=new jpanel(); jpanel pan4=new jpanel(); connection con; stateme
34、nt sql; resultset rs; namequeryform() super(按姓名查询); setsize(400,300); pan1.add(labname); pan1.add(txtname); pan2.add(labdate); pan2.add(txtdate); pan3.add(labscore); pan3.add(txtscore); pan4.add(btnquery); pan4.add(btncancel); pan.setlayout(new gridlayout(3,1); pan.add(pan1); pan.add(pan2); pan.add(
35、pan3); getcontentpane().add(pan,center); getcontentpane().add(pan4,south); btnquery.addactionlistener(this); btncancel.addactionlistener(this); txtdate.seteditable(false); txtscore.seteditable(false); setvisible(true); txtname.requestfocus(); public void actionperformed(actionevent ae) if(ae.getsour
36、ce()=btncancel) dispose(); else if(ae.getsource()=btnquery) try class.forname(sun.jdbc.odbc.jdbcodbcdriver); catch(classnotfoundexception e) trycon=drivermanager.getconnection(jdbc:odbc:sun,gxy,123); sql=con.createstatement(); rs=sql.executequery(select * from 成绩表 where 姓名=+txtname.gettext()+); if(r
37、s.next() txtname.settext(rs.getstring(姓名); txtscore.settext(new integer(rs.getint(成绩).tostring(); txtdate.settext(rs.getdate(出生日期).tostring(); else system.out.println(不存在该记录! ); txtname.settext(); txtscore.settext(); txtdate.settext(); txtname.requestfocus(); catch(sqlexception e) public static void
38、 main(string args) new namequeryform(); 3.5.2 运行效果:3.6.1 按成绩查询数据:/*按成绩查询数据*/import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;import javax.swing.table.defaulttablemodel;import javax.swing.table.jtableheader;public class scorequeryform extends jframe implements actionli
39、stener jlabel labscore=new jlabel(请输入成绩:); jtextfield txtscore=new jtextfield(10); jbutton btnquery=new jbutton(查询); jpanel pan1=new jpanel(); jpanel pan2=new jpanel(); string str=姓名,出生日期,成绩; object data=new object103; jtable table=new jtable(data,str); jtableheader head=table.gettableheader(); jscr
40、ollpane jsp=new jscrollpane(table);/滚动 connection con; statement sql; resultset rs; scorequeryform() super(按成绩查询); setsize(400,300); pan1.add(labscore); pan1.add(txtscore); pan1.add(btnquery);/以上3条在第一个面板加入内容 getcontentpane().add(pan1,north);/把面板1放到窗口顶部 pan2.setlayout(new borderlayout(); pan2.add(head,north);/将表头放在面板2的顶部 pan2.add(jsp,center);/表格放在pan2中间 getcontentpane().add(pan2,center);/把面板2整体加入到主窗口中 btnquery.addact
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 年度工作计划与目标达成的路径设计
- 电子商务与物联网技术的结合应用
- 科技公司的社群营销在社交网络的实施策略
- 现代办公环境下的营养与健康策略
- 桓温文史形象及其符号化研究
- 2025-2030年户外多功能餐桌椅行业跨境出海战略研究报告
- 2025-2030年复古陶瓷酒具套装企业制定与实施新质生产力战略研究报告
- 分泌蛋白SsPEIE1和SsGH5在核盘菌致病中的功能及机制研究
- 面向400MHz DNP-NMR系统的大功率太赫兹传输线研究
- MyoD的O-GlcNAc糖基化修饰对骨骼肌成肌分化的影响及作用机制
- 酶工程技术在茶叶深加工中的应用
- 人教版英语八年级下册全册教案教学设计及教学反思
- 02J401 钢梯【含03年修改】图集
- Android移动应用开发基础教程-教案
- 电梯结构与原理-第2版-全套课件
- 《现代汉语》语音教学上课用课件
- 采购流程各部门关系图
- 力士乐工程机械液压培训资料(共7篇)课件
- 村光伏发电申请书
- 支气管扩张的护理PPT
- 施工现场专项消防安全检查表
评论
0/150
提交评论