简单学生信息管理系统java课程设计范本模板Word文档格式.docx

上传人:b****6 文档编号:20708463 上传时间:2023-01-25 格式:DOCX 页数:15 大小:144KB
下载 相关 举报
简单学生信息管理系统java课程设计范本模板Word文档格式.docx_第1页
第1页 / 共15页
简单学生信息管理系统java课程设计范本模板Word文档格式.docx_第2页
第2页 / 共15页
简单学生信息管理系统java课程设计范本模板Word文档格式.docx_第3页
第3页 / 共15页
简单学生信息管理系统java课程设计范本模板Word文档格式.docx_第4页
第4页 / 共15页
简单学生信息管理系统java课程设计范本模板Word文档格式.docx_第5页
第5页 / 共15页
点击查看更多>>
下载资源
资源描述

简单学生信息管理系统java课程设计范本模板Word文档格式.docx

《简单学生信息管理系统java课程设计范本模板Word文档格式.docx》由会员分享,可在线阅读,更多相关《简单学生信息管理系统java课程设计范本模板Word文档格式.docx(15页珍藏版)》请在冰豆网上搜索。

简单学生信息管理系统java课程设计范本模板Word文档格式.docx

 

2.2系统目标

软件开发的意图便于用户对学生的管理,方便查看学生的情况。

如用户对学生基本信息进行录入、查询、修改、删除等。

2.2使用范围

本系统仅针对用户对少量学生进行信息管理。

2.3功能要求

1录入学生基本信息的功能

   2查询学生基本信息的功能

   3修改学生基本信息的功能

 4删除学生基本信息的功能

  5显示所有学生信息的功能

3设计内容

1界面构建

1、为了便于各种操作,软件采用多窗口的模式。

用户可在不同窗口进行相应操作(录入、查询、修改、删除、显示所有学生省信息)。

 2、主窗口是用户进行各种操作的平台,具体操作在各个独立功能窗口中完成。

   3、主窗口的主要功能位于菜单中,菜单为进入各个功能窗口的唯一通道。

4、当用户在进行个别录入、删除或错误输入操作时,会弹出相应对话框提示用户。

如当录入成功或删除成功,弹出成功以及相应的简明信息提示当,当录入、删除失败以及输入不当是,弹出错误以及简单的错误原因提示用户重新操作。

5、界面布局尽量合理,各组件位置分布均匀美观。

2详细设计

3.2.1模块设

2.2数据库设计

学生信息表

3.2。

3运行调试

操作界面

 

添加学生信息

修改学生信息

查找学生信息

2.4主要源代码

importjava。

sql.Connection;

importjava.sql。

DriverManager;

importjava.sql.PreparedStatement;

importjava.sql.ResultSet;

publicclassSqlHelper   //对数据库进行操作

ﻩPreparedStatementps=null;

Connectionct=null;

ResultSet rs=null;

ﻩStringdriver="

com。

microsoft.jdbc。

sqlserver。

SQLServerDriver"

;

Stringurl=”jdbc:

microsoft:

sqlserver:

//127。

0。

0.1:

1433;

databaseName=Jsql”;

ﻩStringuser="

sa”;

ﻩStringpasswd="

sa”;

ﻩpublicvoid close()

{

ﻩtry{

ﻩﻩif(rs!

=null)rs.close();

ﻩ if(ps!

=null) ps。

close();

ﻩﻩ if(ct!

=null)ct.close();

ﻩﻩ

ﻩﻩcatch(Exceptione)

ﻩ  {

ﻩ e。

printStackTrace();

ﻩ  }

}

ﻩpublicResultSetqueryExecute(Stringsql)

ﻩtry

{

ﻩClass.forName(driver);

ﻩﻩct=DriverManager。

getConnection(url,user,passwd);

ﻩ ps=ct。

prepareStatement(sql);

ﻩﻩrs=ps.executeQuery();

ﻩcatch(Exceptione)

ﻩe。

printStackTrace();

ﻩ}

finally

ﻩﻩ{}

 returnrs;

ﻩ}

//查询数据库操作

ﻩpublic ResultSet queryExectue(Stringsql,String[]paras)

ﻩ{

ﻩtry

ﻩﻩ{

Class。

forName(driver);

ﻩ   ct=DriverManager.getConnection(url,user, passwd);

ﻩﻩﻩps=ct。

prepareStatement(sql);

ﻩﻩfor(inti=0;

 i〈paras。

length;

i++)

ﻩ{

ﻩﻩps。

setString(i+1, paras[i]);

ﻩﻩﻩﻩ}

  rs=ps。

executeQuery();

 }

ﻩﻩcatch(Exceptione)

ﻩ   {

e.printStackTrace();

ﻩ  }

ﻩfinally

ﻩ {}

ﻩreturnrs;

 }

ﻩ//把增、删、改放在一起对数据库操作

ﻩ@SuppressWarnings(”finally”)

public booleanupdExecute(Stringsql,String []paras)

booleanb=true;

ﻩtry

ﻩ{

ﻩClass。

forName(driver);

  ct=DriverManager。

getConnection(url,user,passwd);

ﻩﻩ ps=ct。

prepareStatement(sql);

ﻩﻩ for(inti=0;

i<

paras.length;

 i++)

ﻩﻩ {

ﻩﻩﻩps。

setString(i+1, paras[i]);

ﻩ}

if(ps.executeUpdate()!

=1)

ﻩﻩﻩﻩ{

b=false;

ﻩ }ﻩ

ﻩ   }

ﻩﻩ

ﻩﻩ catch(Exceptione)

ﻩ       {

ﻩﻩﻩb=false;

ﻩﻩﻩe。

printStackTrace();

   }

ﻩ finally

ﻩ    {

ﻩ      returnb;

ﻩﻩﻩﻩ 

ﻩ      }

ﻩ}

importjavax。

swing.*;

importjava。

sql。

*;

importjava。

util。

*;

importjava.sql.Connection;

importjava.sql.DriverManager;

importjava。

sql。

PreparedStatement;

import java.sql。

ResultSet;

importjava。

util。

Vector;

importjava.awt.*;

importjava.awt。

Event.*;

importjava。

awt.event.ActionEvent;

importjava.awt.event。

ActionListener;

//学生管理类

publicclassStuManger extendsJFrameimplements ActionListener

{

 JPaneljp1,jp2;

  JLabeljl1;

 JButton jb1,jb2,jb3,jb4;

 JTable jt;

 JScrollPanejsp;

  JTextFieldjtf;

 StuModms;

public staticvoidmain(String[]args)

 {

ﻩStuMangers=new StuManger();

 

 public StuManger()

 {

 jp1=new JPanel();

 jtf=newJTextField(10);

  ﻩjb1=new JButton("

查询"

);

  

  ﻩjb1.addActionListener(this);

 jl1=newJLabel("

请输入名字"

 ﻩ

ﻩjp1.add(jl1);

ﻩjp1。

add(jtf);

  ﻩjp1。

add(jb1);

  ﻩ

   ﻩjp2=newJPanel();

 ﻩ

 ﻩjb2=newJButton("

添加"

 ﻩjb2。

addActionListener(this);

ﻩjb3=new JButton(”删除”);

 jb3。

addActionListener(this);

ﻩjb4=newJButton("修改”);

  ﻩjb4.addActionListener(this);

jp2.add(jb2);

  ﻩjp2.add(jb3);

 jp2。

add(jb4);

   ﻩ

ﻩms=newStuMod();

 ﻩString[]paras={"

1"

};

 ﻩms。

queryStu("

select*fromstuwhere 1=?

"

,paras);

jt=newJTable(ms);

ﻩjsp=newJScrollPane(jt);

ﻩthis。

add(jsp);

  ﻩthis。

add(jp1,”North"

ﻩthis。

add(jp2,”South”);

ﻩthis。

setSize(400,300);

  this。

setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

 ﻩthis。

setVisible(true);

ﻩpublicvoid actionPerformed(ActionEvent e)

ﻩ//TODOAuto—generatedmethod stub

ﻩﻩif(e.getSource()==jb1){

ﻩﻩSystem.out。

println(”希望查询”);

ﻩﻩStringname=this。

jtf.getText()。

trim();

ﻩStringsql=”select *fromstuwherestuName=?

ﻩStringparas[]={name};

ﻩﻩﻩ

ﻩms=newStuMod();

ﻩms.queryStu(sql,paras);

ﻩjt.setModel(ms);

ﻩelse if(e。

getSource()==jb2)

ﻩ     {

ﻩ  StuAddDialogg=newStuAddDialog(this,”添加学生"

,true);

ﻩﻩﻩ ms=new StuMod();

ﻩﻩ String []paras2={”1”};

ﻩﻩﻩ ms.queryStu(”select*fromstu where 1=?

",paras2);

ﻩjt.setModel(ms);

 

ﻩelseif(e。

getSource()==jb4)

ﻩﻩ{

ﻩﻩintrowNum=this。

jt。

getSelectedRow();

ﻩ if(rowNum==—1)

ﻩ{

ﻩ   JOptionPane.showMessageDialog(this, "

请选择一行");

ﻩ  return;

} 

// 

ﻩnewStuUpdDialog(this,”修改”,true,ms,rowNum);

ﻩms=new StuMod();

ﻩString []paras2={”1"

};

ﻩ  ms。

queryStu(”select*from stuwhere1=?

”,paras2);

ﻩﻩjt。

setModel(ms);

ﻩﻩﻩ StringstuId=(String)ms.getValueAt(rowNum,0);

ﻩﻩSystem.out。

println("

id="

+stuId);

ﻩ}

 //删除

 elseif(e.getSource()==jb3)

ﻩﻩﻩ  introwNum=this。

getSelectedRow();

  if(rowNum==-1)

ﻩ   {

ﻩ  JOptionPane。

showMessageDialog(this, ”请选择一行”);

ﻩﻩ   return;

ﻩ}

  jt.setModel(ms);

ﻩStringstuId=(String)ms。

getValueAt(rowNum,0);

ﻩSystem.out。

println("

id="+stuId);

ﻩﻩStringsql=”delete fromstuwherestuid=?

ﻩﻩﻩString[]paras={stuId};

ﻩﻩStuMod temp=newStuMod();

ﻩtemp。

updStu(sql,paras);

ﻩﻩms=newStuMod();

ﻩﻩString[]paras2={"1”};

ﻩﻩ ms。

queryStu(”select * fromstuwhere1=?

”, paras2);

jt。

setModel(ms);

ﻩﻩ

ﻩﻩ  } 

}

5总结与展望

做课设让我对java有了新的认识,首先我接触了很多上课见过见过但没有实际用过的类和方法,让我对编程有了许多新的思想.

大一学了C语言,虽然当时学的还不错,由于学的都是入门知识,所以自己做的都是DOS下执行的程序,虽然可以实现一定的功能,但和自己平时用的软件相差很大。

这学期刚开课学java感觉没什么新鲜感,它的跨平台特性也只是听听,根本没有认识,知道学到第七章图形界面用户编程的时候,我发现学会之后自己可以做出来的软件就更接近平时使用的软件了,不过由于平时学习不刻苦,到时没有时间静下心来写java代码,知道结课做课设,才静下心来开始研究java,结合以前的编程知识,做起了自己的程序.

我曾经用c语言做过这个系统,做起来会比较熟练,同时想通过做课设学习一点数据库的知识,感觉这些知识更贴近实际应用,选好之后开始准备课设,先从最简单的主窗体,到主窗体的菜单,组件添加,再到各个功能的独立窗体的建立,再到最后的数据库连接,功能的实现,一步步走来,收获颇多。

其中独立窗体中的组件排版是碰到的第一个问题,最简单的方法是在建每个窗体时把所有需要的组件全部重新添加进去,但是这样代码会很长,而却会多占很多内存空间,于是我决定把个功能窗体中共同的组件在一个新方法中统一加载,为了减小占内存空间,组建的在主类的构造方法中生成,所有独立功能窗口公用组件,这样既减少了代码额长度,又提高了程序的内存利用率。

还有很多问题,都在权衡之后得到了较优的解决方法。

它能够使这次课设还让我对java的跨平台性有了进一步认识,当我学好代码兴致勃勃的想把它做成exe可执行文件时,在网上搜索之后发现它似乎很难实现,就是应为它的java语言的实现机制,通过jre来执行执行java代码,而不是调用系统本地代码。

除此之外我还学到了新的编程技巧,比如对try,catch的运用。

刚学的时候就是照书本上的打,很不情愿但是必须打的代码,在做课设时,我发现他又很神奇的功能可以帮助我解决用其他办法不好解决的问题,比如关闭窗口。

刚开始程序只有主窗口时,关闭很好实现,但随着程序功能的完善,需要关闭的窗口越来越多,需要关闭的类型也便多了,到了关闭Dialog的时候,发现Dialog不能强制转化为Frame,如果想用前面的方法管还得把多处代码进行修改,不过我想到了用try来解决这个问题。

     

参考文献

[1]李钟尉,马文强,陈丹丹Java从入门到精通 第1版 清华大学出版社 2008.9

[2]刘万军,梁清华,王松波,宋强Java程序设计实践教程 第1版清华大学出版社2006。

9

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 表格模板 > 表格类模板

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1