學生成績管理系統(tǒng)課程設計5_第1頁
已閱讀1頁,還剩12頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、<p>  課 程 設 計 報 告</p><p>  課程設計名稱:學生成績管理系統(tǒng)</p><p>  系 : </p><p>  學生姓名: ***** </p><p>  班 級: 計算機(3)班 </p><p> 

2、 學 號: ************ </p><p>  成 績: </p><p>  指導教師: **** </p><p>  開課時間:2010-2011學年 2 學期</p><p><b>  一.設計題目</b>

3、</p><p><b>  學生成績管理系統(tǒng)</b></p><p><b>  二.主要內容</b></p><p>  學生成績管理系統(tǒng)從功能上劃分可分為以下幾大模塊:</p><p><b>  1.學生信息管理</b></p><p>  學生

4、信息管理模塊:設置學生基本信息,并可以對學生信息進行添加、修改、刪除。</p><p><b>  2.課程信息管理</b></p><p>  課程信息管理:設置課程號,課程名,任課教師等課程信息,并可以對課程信息進行添加、修改、刪除。</p><p><b>  3.學生成績管理</b></p><

5、;p>  成績信息管理模塊:設置成績信息,并可以對成績信息進行添加、修改、刪除。</p><p>  還可以用關鍵字查詢并調出數據庫里的學生基本成績信息的修改、刪除等。輸出查詢的學生成績信息,并對學生成績總分,平均分等進行統(tǒng)計。</p><p><b>  三.具體要求</b></p><p>  1.具有良好的系統(tǒng)性能,友好的用戶界面

6、</p><p>  2.較高的處理效率,便于使用和維護</p><p>  3.采用成熟的技術開發(fā),是系統(tǒng)具有較高的技術水平和較長的生命周期</p><p>  4.系統(tǒng)盡可能簡化重復工作,提高工作效率簡化數據查詢、降低統(tǒng)計難度</p><p><b>  四.進度安排</b></p><p>

7、<b>  五.成績評定</b></p><p><b>  正文</b></p><p>  系統(tǒng)的需求分析和功能設計</p><p>  需求分析:該學生成績管理系統(tǒng)的開發(fā)是為了能夠讓用戶方便、快速的查找有關于一些學生的基本信息。同時該學生成績管理系統(tǒng)的建立也要要求能夠節(jié)約用戶時間和節(jié)約系統(tǒng)資源等。該系統(tǒng)是由以下幾部分

8、組成:系統(tǒng)管理、學生管理、課程管理、成績管理和信息管理。在系統(tǒng)管理功能中有退出功能;學生成績管理功能中有增加學生、修改學生和刪除學生;課程管理功能中有增加課程、修改課程和刪除課程;成績管理功能中成績增加和成績修改;信息管理功能中學生信息查詢、課程信息查詢和成績查詢。在查詢功能中還有一些子功能。</p><p><b>  功能設計:</b></p><p><b

9、>  1.系統(tǒng)功能結構</b></p><p>  學生成績管理系統(tǒng)分為3大功能模塊,分別為:學生信息管理、課程管理、成績管理。系統(tǒng)各個部分及其包括的具體功能模塊如圖1所示。</p><p>  圖1 系統(tǒng)功能結構圖</p><p><b>  2.數據庫設計</b></p><p>  (1) 數據庫

10、概念結構設計</p><p><b>  局部E-R圖</b></p><p>  學生實體圖:共有6中屬性,包括學號、姓名、性別、出生日期、專業(yè)、籍貫等6種屬性,如圖2所示。</p><p> ?、谡n程實體圖,課程信息實體共有3種屬性,包括課程號,課程名,任課教師等3種屬性,如圖3所示。</p><p><b&g

11、t;  圖3課程實體圖</b></p><p> ?、鄢煽儗嶓w圖,成績信息實體共有3種屬性,包括學生學號,課程名稱,平考試成績,成績信息實體圖如圖4所示。</p><p><b>  圖4成績信息實體圖</b></p><p>  系統(tǒng)E-R圖如圖5所示</p><p>  (2) 數據庫邏輯結構設計<

12、/p><p>  本系統(tǒng)采用ACCESS數據庫,各數據表結構如下:</p><p> ?、賹W生信息表: 如表1所示</p><p><b>  表1 學生信息表</b></p><p> ?、谡n程信息表: 如表2所示</p><p><b>  表2 課程信息表</b></

13、p><p>  ③成績信息表: 如表3所示</p><p><b>  表3 成績信息表</b></p><p><b>  2、源程序及注釋</b></p><p> ?。?)增加學生代碼中主要代碼如下:</p><p>  public void actionPerforme

14、d(ActionEvent e) </p><p>  {if(e.getSource()==clearInfo) //設置清空按鈕功能</p><p>  {sNum.setText("");</p><p>  sBirth.setText("");</p><p>  sMajor.setT

15、ext("");</p><p>  sHome.setText("");</p><p>  sName.setText("");</p><p><b>  }</b></p><p>  else if(e.getSource()==addInfo) /

16、/設置增加按鈕功能</p><p>  { String xh=sNum.getText();</p><p>  String xm=sName.getText();</p><p>  String xb;</p><p>  if(xb1.isSelected()) //判斷所選人的性別</p><p&

17、gt;<b>  xb="男";</b></p><p><b>  else</b></p><p><b>  xb="女";</b></p><p>  String csrq=sBirth.getText();</p><p> 

18、 String zy=sMajor.getText();</p><p>  String jg=sHome.getText();</p><p>  if(xh.equals(""))</p><p>  JOptionPane.showMessageDialog(this,"學號不能為空!!!!","操作提&qu

19、ot;,JOptionPane.ERROR_MESSAGE); //創(chuàng)建學號不能為空提示信息框</p><p>  else if(xm.equals(""))</p><p>  JOptionPane.showMessageDialog(this,"姓名不能為空!!!!","操作提示",JOptionPane.ERROR_

20、MESSAGE); //創(chuàng)建姓名不能為空提示信息框</p><p>  try //用來捕獲異常</p><p>  { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); </p><p>  String url="jdbc:od

21、bc:driver={Microsoft Access Driver (*.mdb)};DBQ=student.mdb"; //連接student數據庫</p><p>  Connection con=DriverManager.getConnection(url); //建立連接</p><p>  Statement stm=con.createStatement()

22、; //創(chuàng)建Statement對象</p><p>  //創(chuàng)建添加學生sql語句</p><p>  String str="insert into xs(xh,xm,xb,csrq,zy,jg) values('"+xh+"','"+xm+"','"+xb+"',&#

23、39;"+csrq+"','"+zy+"','"+jg+"')";</p><p>  int rs=stm.executeUpdate(sqlstr); //更新數據庫記錄</p><p>  if(rs>0) //判斷記錄是否添

24、加</p><p>  {JOptionPane.showMessageDialog(this,"恭喜你,學生信息添加成功!!!!!","提示",JOptionPane.INFORMATION_MESSAGE); //創(chuàng)建信息添加成功提示框</p><p><b>  }</b></p><p>  co

25、n.close(); // 關閉結果集</p><p>  stm.close(); //關閉語句</p><p><b>  }</b></p><p>  catch(Exception E) //用來處理異常</p><p><b

26、>  {</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  public static void main(String arg[]) //

27、創(chuàng)建主函數</p><p>  {new StuInfo(); //調用StuInfo()方法</p><p><b>  }</b></p><p><b>  }</b></p><p> ?。?).修改學生代碼中主要部分代碼如下:<

28、/p><p>  public void actionPerformed(ActionEvent ae)</p><p>  { if(ae.getSource()==btnClear) //設置取消按鈕功能</p><p>  {sNum.setText("");</p><p>  sNum.requestFocus

29、();</p><p><b>  }</b></p><p>  else if(ae.getSource()==btnOk) //設置確定按鈕功能</p><p>  {String xh=sNum.getText();</p><p>  if(xh.equals(""))</p>

30、<p>  JOptionPane.showMessageDialog(this,"學號不能為空!","警告",JOptionPane.ERROR_MESSAGE); 創(chuàng)建提示信息框</p><p><b>  else</b></p><p>  {StuInfo newst=new StuInfo();&l

31、t;/p><p>  newst.sNum.setText(xh);</p><p>  newst.sNum.setEnabled(false); //把學號文本框禁用</p><p>  newst.addInfo.setEnabled(false); //把增加按鈕設置為禁用</p><p>  newst.modify

32、Info.setEnabled(true); //把修改按鈕設置為可用</p><p>  newst.deleteInfo.setEnabled(false); //把刪除按鈕設置為禁用</p><p><b>  try</b></p><p>  { Class.forName("sun.jdbc.odbc.JdbcOdb

33、cDriver"); </p><p>  String url= "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=student.mdb";//連接student數據庫</p><p>  Connection con=DriverManager.getConnection(url);

34、//建立連接</p><p>  Statement stm=con.createStatement();//創(chuàng)建Statement對象</p><p>  String sql ="select * from xs where xh='"+xh+"'"; //按學號查詢學生表中所有數據</p><p>  R

35、esultSet rs= stm.executeQuery(sql); //執(zhí)行sql操作</p><p>  while(rs.next()) //循環(huán)執(zhí)行數據庫中每條記錄</p><p>  {newst.sNum.setText(rs.getString("xh")); // 獲取xh字段</p><p>  newst.

36、sName.setText(rs.getString("xm")); // 獲取xm字段</p><p>  if(rs.getString("xb").equals("男")) //獲取xb字段,判斷所選性別</p><p>  newst.xb1.setSelected(true); </p>

37、<p><b>  else</b></p><p>  newst.xb2.setSelected(true);</p><p>  newst.sMajor.setText(rs.getString("zy"));</p><p>  newst.sHome.setText(rs.getString(&quo

38、t;jg"));</p><p><b>  }</b></p><p>  int n=stm.executeUpdate(sql); // 執(zhí)行sql更新命令</p><p>  if(n>0) //判斷是否修改數據庫</p><p>  JOptionPane.showMessag

39、eDialog(null,"成功修改一條新的紀錄!");</p><p><b>  else</b></p><p>  JOptionPane.showMessageDialog(null, "更新失敗", "錯誤", JOptionPane.ERROR_MESSAGE); </p><

40、;p>  con.close(); //關閉結果集</p><p>  stm.close(); //關閉語句</p><p><b>  }</b></p><p>  catch(Exception e)</p><p>  {System.out.println(e); //輸出信息<

41、;/p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  } </p><p>  public static void main(String[] ar

42、gs) //創(chuàng)造主函數</p><p>  { new xiugai(); //調用xiugai()方法</p><p><b>  }</b></p><p><b>  }</b></p><p> ?。?).學生刪除代碼中主要部分代碼:</p>&l

43、t;p>  public void actionPerformed(ActionEvent e) </p><p>  {if(e.getSource()==button) //設置刪除按鈕</p><p><b>  {</b></p><p><b>  try</b></p><p

44、>  {Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); </p><p>  String url= "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=student.mdb"; //連接student數據庫</p><p>

45、  Connection conn=DriverManager.getConnection(url);//建立連接</p><p>  Statement stmt=conn.createStatement(); //創(chuàng)建Statement對象</p><p>  String sqlstr ="delete from xs where xh='"+sHom

46、e.getText()+"'";//創(chuàng)建刪除從xs表中刪除語句</p><p>  int result= stmt.executeUpdate(sqlstr); //執(zhí)行更新命令</p><p>  if (result>0) //判斷是否刪除</p><p>  {JOptionPane.showMessageDialog(

47、this,"學生刪除成功!","提示",JOptionPane.INFORMATION_MESSAGE);</p><p><b>  }</b></p><p>  conn.close(); // 關閉結果集</p><p>  stmt.close(); //關閉語句</p>

48、<p><b>  }</b></p><p>  catch(Exception E)</p><p><b>  {</b></p><p><b>  } </b></p><p><b>  }</b></p>&

49、lt;p><b>  }</b></p><p>  public static void main(String arg[]) //創(chuàng)建主函數</p><p>  {new scstudent(); //調用scstudent()方法</p><p><b>  }</

50、b></p><p><b>  }</b></p><p>  3、運行示例及結果分析</p><p><b>  (1).主界面</b></p><p>  結果分析:該界面是學生成績管理系統(tǒng)的主界面,從這界面可以看出有幾個功能系統(tǒng)。</p><p><b&g

51、t; ?。?).添加界面</b></p><p>  結果分析:在學生信息中輸入相應的信息后按增加按鈕就會出現恭喜你,學生信息添加成功。</p><p>  如果在輸入信息時,沒有輸入相應的學號和姓名,則會出現相應的提示框提示學號和姓名不能為空。</p><p><b> ?。?).修改界面</b></p><p

52、>  結果分析:在信息框中輸入課程號,按確定按鈕則會跳出相應的課程信息框,如果數據庫中有這一課程號,則會把相應的信息顯示出來,否則只會顯示課程號。</p><p><b> ?。?).刪除界面</b></p><p>  結果分析:在信息框中輸入要刪除的學生學號按確定按鈕,如果所輸入的學號在數據庫中存在,則會跳出學生刪除成功提示框,否則按確定按鈕無效。</

53、p><p><b> ?。?).查詢界面</b></p><p>  結果分析:此結果會從所有的顯示數據中被提取出來,并不是只顯示查詢結果。</p><p>  4、調試和運行程序過程中產生的問題及采取的措施</p><p> ?。?).在調試程序時在定義公共類是出現問題,導致錯誤的原因是類名和java文件名不同,只要pub

54、lic去掉或把java文件名修改成與類名一致。</p><p> ?。?).在調試課程增加程序時,調試結果沒有顯示錯誤,但在運行時增加功能沒有實現,導致錯誤的原因可能是數據庫問題,查找數據庫代碼和數據庫中相應的表發(fā)現課程表中沒有xm這一字段,代碼中出現了,刪除這一字段即可。</p><p> ?。?).在調試主函數代碼時會出現一些找不到符號的問題,有可能時你調用的子函數不在同一個文件下,也

55、有可能是你調用的子函數不存在,還有可能是子函數沒有調試和運行。要想解決問題只要把相應的java文件放在同一個文件下或創(chuàng)建相應的子函數還可以把那些子函數調試和運行一邊,再調試主函數即可。</p><p>  (4).在調試和運行后界面中出現的文字不全和文本框大小與窗體大小不搭調,導致的原因是標簽和文本框大小沒有設置好。只要重新設置一下大小即可。</p><p>  5、對系統(tǒng)相關功能的討論、

56、分析,改進設想</p><p>  該學生成績管理系統(tǒng)的建立主要分為系統(tǒng)管理、學生管理、課程管理、成績管理和信息管理。在這幾個系統(tǒng)功能中有些功能的實現是運用繼承JFrame類和實現監(jiān)聽器ActionListener來實現的。為了更好的實現功能可以創(chuàng)建構造函數來實現初始化。同時也可以創(chuàng)造方法通過方法調用來實現相應的功能。</p><p>  為了進一步完善學生成績管理系統(tǒng)可以有以下改進設想:

57、</p><p>  1).在信息查詢系統(tǒng)功能中增加補考信息查詢菜單項,再補考信息查詢菜單中設置補考學生信息查詢和成績及格學生信息查詢子菜單項。在補考學生信息查詢中添加補考是否通過信息查詢。</p><p>  2).在信息查詢系統(tǒng)功能中添加按學期查詢,在這個查詢中把學生這一學期的所有信息都顯示在界面上。</p><p>  3).在主界面中增加獲獎信息系統(tǒng)功能項,

58、在這中添加獲獎信息,修改獲獎信息,刪除獲獎信息和獲獎信息查詢。在獲獎信息查詢中添加按等級查詢和按競賽查詢。在按等級查詢中只要等級名后按查詢按鈕就會顯示此等級是否通過等這樣的信息;在按競賽查詢中輸入競賽名,則會彈出你有沒有參加此競賽框,如有則按確定按鈕,則會顯示出此同學獲講情況。</p><p>  4).在主界面中添加評價信息系統(tǒng)功能項,此功能主要是為了實現一些人對學生的評價。在這項中分別添加輔導員評價、任課教師

59、評價和同學評價。在輔導員評價中只要輸入學生的學號按確定按鈕就會跳出相應的評價信息;在任課教師評價中輸入學生學號后按確定按鈕,則會跳出要你輸入課程名信息框,輸入課程名后,在按確定按鈕則會跳出課程名和任課教師名點擊查詢則會顯示出相應的信息;在同學評價中只要輸入學生學號即可。</p><p><b>  6、總結</b></p><p>  這次的課程設計任務是開發(fā)學生成績

60、管理系統(tǒng),在開發(fā)的過程中可以看出自己對java知識學到的很少,這次的課程設計能夠讓我學到很多java知識,同時也有利于期末考試。因為該系統(tǒng)的建立幾乎用到了java這學期所學的所有知識。這等于讓我復習了一邊java知識。</p><p>  在創(chuàng)建學生成績管理系統(tǒng)時,要想把界面布局好看些首先要會設置標簽和文本框大小位置,在設置這時用setBounds( ),在這括號中有四個數字分別表示垂直、水平、長度和高度。同時為

61、了防止誤操作一些按鈕和文本框可以利用setEnabled(false)來把按鈕和文本框禁用。要想使該學生成績管理系統(tǒng)實現添加、修改、刪除和查詢功能時就必須與數據庫連接起來。用以下代碼實現數據庫的連接:Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); </p><p>  String url=”jdbc:odbc:drive={Microsoft

62、 Access Driver (*.mdb)};</p><p>  DBQ=student.mdb";Connectionconn=DriverManager.getConnection(url);Statementstmt=</p><p>  conn.createStatement();</p><p>  在設計修改功能時首先要利用查詢語句把

63、查詢出來的結果獲取出來顯示在文本框中,然后再利用SQL的修改語句對相應的信息做出修改,在修改后數據庫中的數據要做出相應的更新來保證數據的正確??梢杂胑xecuteUpdate(sqlstr)來執(zhí)行。在設置性別這一項是可利用單選按鈕來實現。同時還要和ButtonGroup 一起使用才能實現相應的功能。在對事件處理時可用ActionListener監(jiān)聽器和 actionPerformed 方法實現。用代碼實現一定的功能時會發(fā)生一定的異常,這

64、就要用try{ } catch{ }來處理。使用這一語句時要知道try只能有一個而catch可以有多個,finally和catch可以同時出現,但finally和catch至少要出現一個,并且不管異常是否會發(fā)生,finally語句塊都會執(zhí)行。</p><p>  在這次的課程設計中我懂得了要想作出好的系統(tǒng)光靠書本上的那些知識是萬萬不夠的,要不斷的看系統(tǒng)開發(fā)之類的書和自己動手實踐才能夠學到相應的知識。同時一個人學習

65、是孤學而無有,相互學習才是最有效的。</p><p><b>  7、參考文獻</b></p><p>  [1].張亦揮 馮華 胡潔 Java面向對象程序設計 人名郵電出版社 2010年9月</p><p>  [2].黃小東 Java課程設計按例精編 中國水利水電出版社 2004年5月</p><p>

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論