版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p><b> 目 錄</b></p><p><b> 概述3</b></p><p><b> 一、課題介紹3</b></p><p> 二、目的和要求3</p><p><b> 三、任務(wù)計劃3</b></
2、p><p><b> 需求分析5</b></p><p> 一、學(xué)生管理系統(tǒng)的發(fā)展現(xiàn)狀5</p><p> 二、系統(tǒng)功能分析5</p><p> 三、系統(tǒng)結(jié)構(gòu)框圖5</p><p><b> 數(shù)據(jù)庫設(shè)計7</b></p><p>
3、 一、創(chuàng)建數(shù)據(jù)表的結(jié)構(gòu)7</p><p> 二、各表功能及其關(guān)系7</p><p> 系統(tǒng)模塊功能的實現(xiàn)與界面設(shè)計8</p><p> 一、系統(tǒng)主要模塊8</p><p><b> 二、歡迎界面9</b></p><p> 三、主菜單界面9</p>
4、<p><b> 四、子菜單10</b></p><p> 五、學(xué)生信息錄入11</p><p> 六、學(xué)生信息查找12</p><p> 七、學(xué)生信息刪除13</p><p> 八、學(xué)生信息修改14</p><p><b> 課程設(shè)計心得15
5、</b></p><p> 一、程序結(jié)構(gòu)設(shè)計培養(yǎng)15</p><p> 二、書寫習(xí)慣養(yǎng)成15</p><p> 三、注意程序簡潔15</p><p><b> 總結(jié)16</b></p><p><b> 參考文獻17</b></p&
6、gt;<p> 附錄:項目源代碼18</p><p> 一、數(shù)據(jù)庫連接(DbConnection.java)18</p><p> 二、學(xué)生信息數(shù)據(jù)庫管理(Student_Dao.java)18</p><p> 三、歡迎界面(Welcome.java)23</p><p> 四、主菜單界面(Menu.
7、java)24</p><p> 五、子菜單界面(Son_Menu.java)27</p><p> 六、添加功能(Add_Menu.java)31</p><p> 七、查找功能(Find_Menu.java)34</p><p> 八、刪除功能(Delet_Menu.java)36</p><
8、p> 九、修改功能(Change_Menu.java)38</p><p><b> 概述</b></p><p><b> 課題介紹</b></p><p> 本次課程設(shè)計要求實現(xiàn)一個面向?qū)W生信息的管理系統(tǒng)。學(xué)生信息系統(tǒng)是一個非常通用的管理系統(tǒng)。很多大、中、小學(xué)校都需要擁有自己的學(xué)生檔案管理系統(tǒng),以便對
9、本校學(xué)生的基本信息和學(xué)習(xí)情況進行管理,另一方面,較完整的學(xué)校信息管理系統(tǒng)同樣也需要有學(xué)生信息管理系統(tǒng)的支持。</p><p> 由通用的學(xué)生相關(guān)數(shù)據(jù)分析可知,系統(tǒng)包括院系管理、學(xué)生基本信息管理、課程管理、學(xué)生從成績管理等主要功能。</p><p> 該系統(tǒng)要求使用JAVA和MySQL作為開發(fā)工具和數(shù)據(jù)庫管理系統(tǒng),因此,系統(tǒng)設(shè)計涉及系統(tǒng)功能設(shè)計、數(shù)據(jù)庫設(shè)計和系統(tǒng)界面等幾個方面內(nèi)容。<
10、;/p><p><b> 目的和要求</b></p><p> 了解JAVA語言的特點及使用的范圍,掌握開發(fā)軟件平臺的搭建。</p><p> 要求使用JAVA和MySQL開發(fā)一個學(xué)生信息管理系統(tǒng),系統(tǒng)主要功能如下:</p><p><b> 院系信息管理</b></p><
11、p> 院系系統(tǒng)信息的錄入,包括院系編號、院系名稱等信息;</p><p> 院系信息的修改、刪除、查詢。</p><p><b> 學(xué)生基本信息管理</b></p><p> 學(xué)生基本信息的錄入,包括學(xué)號、姓名、性別、出生日期、所在院系、班級等信息;</p><p> 學(xué)生基本信息的修改、刪除、查詢。&l
12、t;/p><p><b> 課程設(shè)置管理</b></p><p> 課程信息的錄入,包括課程編號、課程名稱、學(xué)分、課程內(nèi)容等信息;</p><p> 課程信息的修改、刪除、查詢。</p><p><b> 學(xué)生成績管理</b></p><p> 學(xué)生成績的錄入,包括課程
13、編號、課程名稱、學(xué)分、課程內(nèi)容等信息;</p><p> 學(xué)生信息的修改、刪除、查詢。</p><p><b> 任務(wù)計劃</b></p><p> 考慮到本次課程設(shè)計是獨立完成,所以,不需要進行細致的分工,只要對框架和時間進行一定的規(guī)劃就行。</p><p><b> 需求分析</b>&l
14、t;/p><p> 學(xué)生管理系統(tǒng)的發(fā)展現(xiàn)狀</p><p> 經(jīng)過了一段時間的發(fā)展,當今,各大高校普遍都有了相對完善的學(xué)生管理系統(tǒng),但在部分中小學(xué)中,這種高效的管理手段,仍未能全面普及。目前已有的學(xué)生管理系統(tǒng)存在界面和操作相對繁瑣,實現(xiàn)成本較高等缺點,仍需改進。</p><p><b> 系統(tǒng)功能分析</b></p><p
15、> 由通用的學(xué)生相關(guān)數(shù)據(jù)分析可知,系統(tǒng)包括院系管理、學(xué)生基本信息管理、課程管理、學(xué)生從成績管理等主要功能。</p><p> 實現(xiàn)以上各模塊的功能,需要以下子功能:</p><p> 1數(shù)據(jù)庫連接的建立與斷開</p><p> 2數(shù)據(jù)庫的數(shù)據(jù)操作,包括插入、查詢、刪除、修改</p><p> 系統(tǒng)操作界面與數(shù)據(jù)庫操作相關(guān)聯(lián)&l
16、t;/p><p><b> 系統(tǒng)結(jié)構(gòu)框圖</b></p><p> 從系統(tǒng)功能表述可以看出,該系統(tǒng)可以實現(xiàn)幾個功能,根據(jù)這些功能設(shè)計出系統(tǒng)的功能模塊如 圖表 1所示:</p><p><b> 數(shù)據(jù)庫設(shè)計</b></p><p><b> 創(chuàng)建數(shù)據(jù)表的結(jié)構(gòu)</b></
17、p><p> (以學(xué)生基本信息管理系統(tǒng)為例)</p><p><b> 主要數(shù)據(jù)項</b></p><p> 學(xué)號、姓名、性別、出生年月、所在院系、所在班級</p><p><b> 數(shù)據(jù)類型及要求</b></p><p> 為操作方便,均定義為字符串。其中學(xué)號不得重復(fù)
18、。</p><p><b> MySQL建表語句</b></p><p><b> 各表功能及其關(guān)系</b></p><p> 本系統(tǒng)各表分別存儲相應(yīng)數(shù)據(jù)。</p><p> 涉及的數(shù)據(jù)表之間相對獨立,但仍有少量關(guān)聯(lián)。</p><p> 學(xué)生成績表 包含對 學(xué)生基本
19、信息表 和 課程設(shè)置表 的映射</p><p> 學(xué)生基本信息表 包含對 院系信息表 的映射</p><p> 系統(tǒng)模塊功能的實現(xiàn)與界面設(shè)計</p><p><b> 系統(tǒng)主要模塊</b></p><p> 本次課程設(shè)計的主要目的,是通過實踐,讓我對所學(xué)到的知識進行考驗和鞏固。經(jīng)過一點時間的了解。設(shè)計出了系統(tǒng)的總
20、體框架,參看圖表 1。</p><p> 由于各模塊的功能及原理基本相同,只是涉及的數(shù)據(jù)類型有所不同,所以本次只對學(xué)生基本信息管理的功能進行了較為全面的設(shè)計。由于時間關(guān)系,其余功能沒有進行具體設(shè)計。(具體的在以下說明中會提及)</p><p><b> 系統(tǒng)界面設(shè)計如下:</b></p><p><b> 數(shù)據(jù)庫管理模塊:<
21、;/b></p><p> 模塊功能界面設(shè)計如下:</p><p><b> 歡迎界面</b></p><p> 實際運行效果(圖表 2)</p><p><b> 實現(xiàn)方法</b></p><p> 繼承了JPanel,并在構(gòu)造函數(shù)中建立JFrame做外框;
22、</p><p> 用JLabel顯示歡迎信息內(nèi)容;</p><p> 確定按鈕在監(jiān)聽到事件后,new出一個Menu類;</p><p><b> 主菜單界面</b></p><p> 實際運行效果(圖表 3)</p><p><b> 實現(xiàn)方法</b></p
23、><p> 繼承JFrame類,在內(nèi)部建立的JPanel插入JButton;</p><p> 定義相應(yīng)按鈕的響 應(yīng)事件,調(diào)用子菜單的不同建立函數(shù)(如new Son_menu().studentmenu(););</p><p><b> 子菜單</b></p><p> 實際運行效果(圖表 4)</p>
24、<p><b> 實現(xiàn)方法</b></p><p> 建立JFrame,JTable,JButton等工具;</p><p><b> 建立數(shù)據(jù)庫鏈接;</b></p><p> 將數(shù)據(jù)庫里的數(shù)據(jù)逐個讀入到JTable類;</p><p> 對JButton加入ActionL
25、istener,并關(guān)聯(lián)相應(yīng)的功能菜單,如:</p><p><b> 學(xué)生信息錄入</b></p><p> 實際運行效果(圖表5)</p><p><b> 實現(xiàn)方法</b></p><p> 由輸入的學(xué)生信息構(gòu)造一個Student類;</p><p> 利用SQ
26、L語句,將Student類插入到數(shù)據(jù)庫;</p><p><b> 學(xué)生信息查找</b></p><p> 1.實際運行效果(圖標 6)</p><p><b> 實現(xiàn)方法</b></p><p> 1)由輸入的學(xué)號,利用SQL語句找到相關(guān)數(shù)據(jù),返回一個Student類;</p>
27、<p> 2)有則將student的相關(guān)信息顯示到JTextArea上,沒有則顯示“學(xué)生信息未找到”;</p><p><b> 學(xué)生信息刪除</b></p><p> 實際運行效果(圖表 7)</p><p><b> 實現(xiàn)方法</b></p><p> 應(yīng)用查找功能相似的
28、原理先搜索到要刪除的信息;</p><p> 利用SQL語句將找到的信息刪除,并顯示“學(xué)生信息以刪除”。</p><p><b> 學(xué)生信息修改</b></p><p><b> 實際運行效果</b></p><p><b> 實現(xiàn)方法</b></p>&
29、lt;p> 應(yīng)用查找功能相似的原理先搜索到要修改的信息;</p><p> 應(yīng)用刪除功能相似的原理刪除要修改的信息;</p><p> 調(diào)用錄入類,錄入要修改的新信息;</p><p><b> 課程設(shè)計心得</b></p><p> 程序結(jié)構(gòu)設(shè)計思路培養(yǎng)</p><p> 為了
30、簡化程序,我并沒有為每個窗口都建一個類,而是把類似的窗口例如student_add,depart_add等建一個類Add_Menu,調(diào)用不同的函數(shù)建立不同窗口,如:student_add(),depart_add();</p><p><b> 書寫習(xí)慣的養(yǎng)成</b></p><p> 好的書寫習(xí)慣是一個優(yōu)秀程序員的必備品質(zhì)。在寫代碼的時候要隨時注意書寫的格式。&
31、lt;/p><p> 如:1.賦值語句的“=”的左右應(yīng)該用空格隔開;</p><p><b> a=1;</b></p><p><b> 改為</b></p><p><b> a = 1;</b></p><p><b> 這樣更
32、為清晰;</b></p><p> 2.大括號一定要對齊;</p><p><b> class {</b></p><p><b> ……</b></p><p> public void …..{</p><p><b> …….</
33、b></p><p><b> }</b></p><p><b> }</b></p><p><b> 注意程序簡潔</b></p><p> 在逐漸適應(yīng)面向?qū)ο缶幊桃院蟆R廊粦?yīng)道保持過去在編程中的一些好習(xí)慣。使用Vector等,也需要留意效率。不能只顧用法方
34、便。</p><p><b> 總結(jié)</b></p><p> 系統(tǒng)設(shè)計過程中,主要涉及了包括JAVA基本語法、AWT,Java Swing,MySQL等方面的相關(guān)知識。設(shè)計中遇到不少問題,到圖書館查閱了不少資料,向王宋君老師請教過不少問題,老師都一一細心解答,非常感謝。由于時間倉促,原本設(shè)想的功能還沒有一一實現(xiàn),待進一步完善。</p><p&
35、gt;<b> 參考文獻</b></p><p> 《Thinking in Java(Java編程思想)》第四版,機械工業(yè)出版社,【美】Bruce Eckel著,陳昊鵬譯;</p><p> 《精通Java Swing程序設(shè)計》中國鐵道出版社,林智揚、范明翔、陳錦輝 編著;</p><p> 《深入淺出Java Swing程序設(shè)計》中
36、國鐵道出版社,林智揚、范明翔、陳錦輝 編著;</p><p> 《Java GUI程序設(shè)計》清華大學(xué)出版社,肖剛 等編著;</p><p> 《Java信息系統(tǒng)設(shè)計與開發(fā)實例》機械工業(yè)出版社,黃明、梁旭、曹利超 編著;</p><p> 《Java范例大全》機械工業(yè)出版社,尹繼平、張帆 編著;</p><p><b> 附錄
37、:項目源代碼</b></p><p> 數(shù)據(jù)庫連接(DbConnection.java)</p><p> package dao;</p><p> import java.sql.Connection;</p><p> import java.sql.DriverManager;</p><p&g
38、t; import java.sql.SQLException;</p><p> public class DbConnection {</p><p> public static Connection getConnection(){</p><p> Connection con = null;</p><p> Strin
39、g url = "jdbc:mysql://localhost:3306/java";</p><p> String userName= "root";</p><p> String password = "l057788y";</p><p><b> try {</b>&
40、lt;/p><p> Class.forName("com.mysql.jdbc.Driver");</p><p> con = DriverManager.getConnection(url,userName,password);</p><p> System.out.println("數(shù)據(jù)庫連接成功");</p
41、><p> } catch (ClassNotFoundException e) {</p><p> // TODO Auto-generated catch block</p><p> e.printStackTrace();</p><p> return null;</p><p> } catch (
42、SQLException e) {</p><p> // TODO Auto-generated catch block</p><p> e.printStackTrace();</p><p><b> }</b></p><p> return con;</p><p><b
43、> }</b></p><p> public static void closeConnection(Connection con){</p><p> if(con!=null){</p><p><b> try {</b></p><p> con.close();</p>
44、<p> con = null;</p><p> } catch (SQLException e) {</p><p> // TODO Auto-generated catch block</p><p> e.printStackTrace();</p><p><b> }</b><
45、/p><p><b> }</b></p><p><b> }</b></p><p> public static void main(String args[]){</p><p> getConnection();</p><p><b> }<
46、/b></p><p><b> }</b></p><p><b> }</b></p><p> 學(xué)生信息數(shù)據(jù)庫管理(Student_Dao.java)</p><p> package dao;</p><p> import java.sql.Con
47、nection;</p><p> import java.sql.PreparedStatement;</p><p> import java.sql.ResultSet;</p><p> import java.sql.SQLException;</p><p> import java.sql.Statement;</
48、p><p> import java.util.ArrayList;</p><p> import model.Depart;</p><p> import model.Student;</p><p> public class StudentDao {</p><p> public boolean ad
49、dInfo(Student student){</p><p> boolean flag;</p><p> Connection con = DbConnection.getConnection();</p><p> PreparedStatement ps;</p><p> String sql = ""
50、;</p><p> //ResultSet rs;</p><p><b> try {</b></p><p> sql = "insert into student values(?,?,?,?,?,?)"; //用問號代替</p><p> ps = con.prepareStat
51、ement(sql);</p><p> ps.setInt(1, student.getId());</p><p> ps.setString(2, student.getName());</p><p> ps.setString(3, student.getSex());</p><p> ps.setString(4, st
52、udent.getBorn_date());</p><p> ps.setString(5, student.getDepart_id());</p><p> ps.setString(6, student.getClass_name());</p><p> ps.execute();</p><p> System.out.p
53、rintln("添加了一條記錄");</p><p> flag = true;</p><p> } catch (SQLException e) {</p><p> // TODO Auto-generated catch block</p><p> e.printStackTrace();</p&g
54、t;<p> flag = false;</p><p><b> }finally{</b></p><p> DbConnection.closeConnection(con);</p><p><b> }</b></p><p> return flag;</
55、p><p><b> }</b></p><p> public ArrayList<Student> findAll(){</p><p> ArrayList<Student> students = new ArrayList<Student>();</p><p> Conn
56、ection con = DbConnection.getConnection();</p><p> Statement sta;</p><p> ResultSet rs;</p><p><b> try {</b></p><p> sta = con.createStatement();</p&
57、gt;<p> rs = sta.executeQuery("SELECT * FROM student"); //從表depart中查詢所有數(shù)據(jù)</p><p> while(rs.next()){</p><p> Student student = new Student();</p><p> student.se
58、tId(rs.getInt(1));</p><p> student.setName(rs.getString(2));</p><p> student.setSex(rs.getString(3));</p><p> student.setBorn_date(rs.getString(4));</p><p> student
59、.setDepart_id(rs.getString(5));</p><p> student.setClass_name(rs.getString(6));</p><p> System.out.println(student.getName());</p><p> students.add(student);</p><p>
60、<b> }</b></p><p> rs.close();</p><p> sta.close();</p><p> } catch (SQLException e) {</p><p> // TODO Auto-generated catch block</p><p>
61、e.printStackTrace();</p><p><b> }finally{</b></p><p> DbConnection.closeConnection(con);</p><p><b> }</b></p><p> return students;</p>
62、<p><b> }</b></p><p> public Student findOne(int id){</p><p> Student student = new Student();</p><p> Connection con = DbConnection.getConnection();</p>
63、;<p> PreparedStatement ps;</p><p> String sql = "";</p><p> ResultSet rs;</p><p><b> try {</b></p><p> sql = "SELECT * FROM stud
64、ent where id=?";</p><p> ps = con.prepareStatement(sql);</p><p> ps.setInt(1, id);</p><p> rs = ps.executeQuery(); //從表depart中查詢所有數(shù)據(jù)</p><p> if(rs.next()){
65、</p><p> student.setId(rs.getInt("id")); //注意數(shù)據(jù)類型要對應(yīng)</p><p> student.setName(rs.getString("Name"));</p><p> student.setSex(rs.getString("Sex"));<
66、;/p><p> student.setBorn_date(rs.getString("birthday"));</p><p> student.setDepart_id(rs.getString("Depart"));</p><p> student.setClass_name(rs.getString("C
67、lass"));</p><p> System.out.println("id:"+student.getId()+" name:"+student.getName());</p><p><b> }else{</b></p><p> System.out.println(&quo
68、t;沒有數(shù)據(jù)");</p><p><b> }</b></p><p> rs.close();</p><p> ps.close();</p><p> } catch (SQLException e) {</p><p> // TODO Auto-generated
69、catch block</p><p> e.printStackTrace();</p><p><b> }finally{</b></p><p> DbConnection.closeConnection(con);</p><p><b> }</b></p><
70、;p> return student;</p><p><b> }</b></p><p> public boolean deleteInfo(Student student){</p><p> boolean flag;</p><p> Connection con = DbConnection
71、.getConnection();</p><p> PreparedStatement ps;</p><p> String sql = "";</p><p><b> try {</b></p><p> sql = "delete from student where i
72、d=?"; //用問號代替</p><p> ps = con.prepareStatement(sql);</p><p> ps.setInt(1, student.getId());</p><p> ps.execute();</p><p> System.out.println("成功刪除了一條記錄&q
73、uot;);</p><p> flag = true;</p><p> } catch (SQLException e) {</p><p> // TODO Auto-generated catch block</p><p> e.printStackTrace();</p><p> flag =
74、 false;</p><p><b> }finally{</b></p><p> DbConnection.closeConnection(con);</p><p><b> }</b></p><p> return flag;</p><p><b&
75、gt; }</b></p><p><b> }</b></p><p> 歡迎界面(Welcome.java)</p><p> package menu;</p><p> import java.awt.BorderLayout;</p><p> import ja
76、va.awt.Font;</p><p> import java.awt.GridLayout;</p><p> import java.awt.event.MouseAdapter;</p><p> import java.awt.event.MouseEvent;</p><p> import java.awt.event
77、.WindowAdapter;</p><p> import java.awt.event.WindowEvent;</p><p> import javax.swing.*;</p><p> public class Welcome {</p><p> JFrame w = new JFrame("manageme
78、ntsystem");</p><p> JPanel p1 = new JPanel(); </p><p> JPanel p2 = new JPanel(); </p><p> JLabel l = new JLabel("歡迎進入學(xué)生信息管理系統(tǒng)!");</p><p> JButton b =
79、 new JButton("確定");</p><p> Welcome(){</p><p> w.addWindowListener(new Wind());</p><p> b.addMouseListener(new Monitor2());</p><p> Font font = new
80、 Font( "歡迎進入學(xué)生信息管理系統(tǒng)!", Font.PLAIN, 40); </p><p> l.setFont(font);</p><p> w.add(p1,BorderLayout.CENTER);</p><p> w.add(p2,BorderLayout.SOUTH);</p><p>
81、; p1.add(l);</p><p> l.setBounds(p1.WIDTH/2-100,p1.HEIGHT/2-10,200,20); </p><p> p2.add(b);</p><p> b.setBounds(p2.WIDTH/2-10,p2.HEIGHT/2-6,20,12);</p><p> w.se
82、tBounds(400, 200, 600, 200);</p><p> w.setVisible(true);</p><p><b> }</b></p><p> private class Monitor2 extends MouseAdapter{</p><p> public void mouse
83、Pressed(MouseEvent e) {</p><p> new Menu();</p><p> w.setVisible(false);</p><p><b> }</b></p><p><b> }</b></p><p> public stat
84、ic void main(String args[]){</p><p> new Welcome();</p><p><b> }</b></p><p> private class Wind extends WindowAdapter{</p><p> public void windowClosing
85、(WindowEvent e) {</p><p> w.setVisible(false);</p><p> System.exit(0);</p><p><b> }</b></p><p><b> }</b></p><p><b> }&l
86、t;/b></p><p> 主菜單界面 (Menu.java) </p><p> package menu;</p><p> import java.awt.*;</p><p> import java.awt.event.ActionEvent;</p><p> import java.a
87、wt.event.ActionListener;</p><p> import java.awt.event.WindowAdapter;</p><p> import java.awt.event.WindowEvent;</p><p> import javax.swing.*;</p><p> public class
88、Menu {</p><p> JFrame f = new JFrame("菜單");</p><p> JPanel p = new JPanel();</p><p><b> Menu(){</b></p><p> JButton b_depart = new JButton(&qu
89、ot;院系信息");</p><p> JButton b_student = new JButton("學(xué)生信息");</p><p> JButton b_course = new JButton("課程信息");</p><p> JButton b_score = new JButton("成
90、績信息");</p><p> JButton ex = new JButton("退出");</p><p> b_score.addActionListener(new Monitor2());</p><p> ex.addActionListener(new Monitor2());</p><p>
91、; b_depart.addActionListener(new Monitor2());</p><p> b_student.addActionListener(new Monitor2());</p><p> b_course.addActionListener(new Monitor2());</p><p> f.addWindowListene
92、r(new Wind());</p><p><b> f.add(p);</b></p><p> p.setLayout(new GridLayout(1,2));</p><p> JLabel l = new JLabel();</p><p> JPanel p2 = new JPanel();<
93、/p><p><b> p.add(l);</b></p><p> p.add(p2);</p><p> p2.setLayout(new GridLayout(5,1));</p><p> p2.add(b_depart);</p><p> p2.add(b_student);&l
94、t;/p><p> p2.add(b_course);</p><p> p2.add(b_score);</p><p> p2.add(ex);</p><p> f.setBounds(400,200,400,400);</p><p> f.setVisible(true);</p><
95、;p><b> }</b></p><p> public static void main(String args[]){</p><p> new Menu();</p><p><b> }</b></p><p> private class Wind extends Win
96、dowAdapter{</p><p> public void windowClosing(WindowEvent e) {</p><p> f.setVisible(false);</p><p> System.exit(0);</p><p><b> }</b></p><p&g
97、t;<b> }</b></p><p> private class Monitor2 implements ActionListener{</p><p> public void actionPerformed(ActionEvent e) {</p><p> if(e.getActionCommand().equals(&qu
98、ot;退出")){</p><p> new Menu();</p><p> System.exit(0); </p><p><b> }</b></p><p> if(e.getActionCommand().equals("學(xué)生信息")){</p>&
99、lt;p> new Son_menu().studentmenu();</p><p> f.setVisible(false); </p><p><b> }</b></p><p> if(e.getActionCommand().equals("院系信息")){</p><p
100、> new Son_menu().departmenu();</p><p> f.setVisible(false); </p><p><b> }</b></p><p> if(e.getActionCommand().equals("課程信息")){</p><p>
101、 new Son_menu().coursemenu();</p><p> f.setVisible(false); </p><p><b> }</b></p><p> if(e.getActionCommand().equals("成績信息")){</p><p> new
102、Son_menu().scoremenu();</p><p> f.setVisible(false); </p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p>
103、;<b> }</b></p><p> 子菜單界面(Son_Menu.java)</p><p> package menu;</p><p> import java.awt.BorderLayout;</p><p> import java.awt.GridLayout;</p><
104、p> import java.awt.event.ActionEvent;</p><p> import java.awt.event.ActionListener;</p><p> import java.util.ArrayList;</p><p> import java.util.Vector;</p><p>
105、 import javax.swing.*;</p><p> import javax.swing.table.DefaultTableModel;</p><p> import model.Student;</p><p> import dao.StudentDao;</p><p> public class Son_men
106、u {</p><p> JFrame f ;</p><p> JPanel p1 = new JPanel();</p><p> JPanel p2 = new JPanel();</p><p> JButton b_add = new JButton("錄入");</p><p>
107、; JButton b_delet = new JButton("刪除");</p><p> JButton b_change = new JButton("修改");</p><p> JButton b_find = new JButton("查找");</p><p> JButton b_
108、return = new JButton("返回");</p><p><b> JTable t;</b></p><p> DefaultTableModel tableModel= null;</p><p> public static void main(String args[]){</p>
109、<p> new Son_menu().studentmenu();</p><p><b> }</b></p><p><b> //學(xué)生信息菜單</b></p><p> public void studentmenu(){</p><p> f = new JFrame
110、("學(xué)生信息");</p><p> ArrayList scan = new ArrayList();</p><p> Vector columnNames = new Vector();</p><p> columnNames.add("學(xué)號");</p><p> columnName
111、s.add("姓名");</p><p> columnNames.add("性別");</p><p> columnNames.add("出生年月");</p><p> columnNames.add("學(xué)院代碼");</p><p> column
112、Names.add("所在班級");</p><p> tableModel = new DefaultTableModel(columnNames,0);</p><p> tableModel.addRow(columnNames);</p><p> StudentDao ddao = new StudentDao();</p&
113、gt;<p> scan = ddao.findAll();</p><p> for(int i=0;i<scan.size();i++){</p><p> Vector v = new Vector(); </p><p> Student student = (Student)scan.get(i);</p><
114、;p> v.add(student.getId());</p><p> v.add(student.getName());</p><p> v.add(student.getSex());</p><p> v.add(student.getBorn_date());</p><p> v.add(student.getD
115、epart_id());</p><p> v.add(student.getClass_name());</p><p> tableModel.addRow(v);</p><p><b> }</b></p><p> t = new JTable(tableModel);</p><p
116、> t.setVisible(true);</p><p> f.setLayout(new BorderLayout());</p><p> f.add(p1,BorderLayout.NORTH);</p><p> f.add(p2,BorderLayout.SOUTH);</p><p> f.setBounds(4
117、00,200,600,400);</p><p> p1.add(t);</p><p> b_add.setActionCommand("學(xué)生錄入");</p><p> b_delet.setActionCommand("學(xué)生刪除");</p><p> b_change.setAction
118、Command("學(xué)生修改");</p><p> b_find.setActionCommand("學(xué)生查找");</p><p> b_add.addActionListener(new Monitor2());</p><p> b_delet.addActionListener(new Monitor2());&
119、lt;/p><p> b_change.addActionListener(new Monitor2());</p><p> b_find.addActionListener(new Monitor2());</p><p> b_return.addActionListener(new Monitor2());</p><p> p2
120、.add(b_add);</p><p> p2.add(b_delet);</p><p> p2.add(b_change);</p><p> p2.add(b_find);</p><p> p2.add(b_return);</p><p> f.setVisible(true);</p>
121、;<p><b> }</b></p><p><b> //院系信息菜單</b></p><p> public void departmenu(){</p><p> f = new JFrame("院系信息");</p><p> t = new J
122、Table(100,2);</p><p> t.setVisible(true);</p><p> f.setLayout(new BorderLayout());</p><p> f.add(p1,BorderLayout.NORTH);</p><p> f.add(p2,BorderLayout.SOUTH);</p
123、><p> f.setBounds(400,200,400,400);</p><p> p1.add(t);</p><p> b_add.setActionCommand("院系錄入");</p><p> b_delet.setActionCommand("院系刪除");</p>
124、<p> b_change.setActionCommand("院系修改");</p><p> b_find.setActionCommand("院系查找");</p><p> b_add.addActionListener(new Monitor2());</p><p> b_delet.addAc
125、tionListener(new Monitor2());</p><p> b_change.addActionListener(new Monitor2());</p><p> b_find.addActionListener(new Monitor2());</p><p> b_return.addActionListener(new Monitor
126、2());</p><p> p2.add(b_add);</p><p> p2.add(b_delet);</p><p> p2.add(b_change);</p><p> p2.add(b_find);</p><p> p2.add(b_return);</p><p>
127、 f.setVisible(true);</p><p><b> }</b></p><p><b> //課程信息菜單</b></p><p> public void coursemenu(){</p><p> f = new JFrame("課程信息");&l
128、t;/p><p> t = new JTable(100,2);</p><p> t.setVisible(true);</p><p> f.setLayout(new BorderLayout());</p><p> f.add(p1,BorderLayout.NORTH);</p><p> f.add
129、(p2,BorderLayout.SOUTH);</p><p> f.setBounds(400,200,400,400);</p><p> p1.add(t);</p><p> b_add.setActionCommand("課程錄入");</p><p> b_delet.setActionCommand
130、("課程刪除");</p><p> b_change.setActionCommand("課程修改");</p><p> b_find.setActionCommand("課程查找");</p><p> b_add.addActionListener(new Monitor2());</p
131、><p> b_delet.addActionListener(new Monitor2());</p><p> b_change.addActionListener(new Monitor2());</p><p> b_find.addActionListener(new Monitor2());</p><p> b_return
132、.addActionListener(new Monitor2());</p><p> p2.add(b_add);</p><p> p2.add(b_delet);</p><p> p2.add(b_change);</p><p> p2.add(b_find);</p><p> p2.add(b
133、_return);</p><p> f.setVisible(true);</p><p><b> }</b></p><p><b> //成績信息菜單</b></p><p> public void scoremenu(){</p><p> f = ne
134、w JFrame("成績信息");</p><p> t = new JTable(100,2);</p><p> t.setVisible(true);</p><p> f.setLayout(new BorderLayout());</p><p> f.add(p1,BorderLayout.NORTH)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- java+mysql學(xué)生信息管理系統(tǒng)課程設(shè)計報告
- java課程設(shè)計--學(xué)生信息管理系統(tǒng)
- 學(xué)生信息管理系統(tǒng)java課程設(shè)計
- java課程設(shè)計---學(xué)生信息管理系統(tǒng)
- java課程設(shè)計--學(xué)生信息管理系統(tǒng)
- java課程設(shè)計-學(xué)生信息管理系統(tǒng)
- java課程設(shè)計--基于cs學(xué)生信息管理系統(tǒng)
- java課程設(shè)計---學(xué)生信息管理系統(tǒng)
- java課程設(shè)計報告--學(xué)生信息管理系統(tǒng)
- java課程設(shè)計報告---學(xué)生信息管理系統(tǒng)
- 學(xué)生個人信息管理系統(tǒng)java課程設(shè)計
- java課程設(shè)計--員工信息管理系統(tǒng)
- 高考信息管理系統(tǒng)--java課程設(shè)計
- java課程設(shè)計-- 學(xué)生個人信息管理系統(tǒng)
- java課程設(shè)計--員工信息管理系統(tǒng)
- 學(xué)生個人信息管理系統(tǒng)java課程設(shè)計
- java課程設(shè)計--員工信息管理系統(tǒng)報告
- java學(xué)生基本信息管理課程設(shè)計
- 面向?qū)ο笳n程設(shè)計---用java開發(fā)的學(xué)生信息管理系統(tǒng)
- 圖書信息管理系統(tǒng)java課程設(shè)計
評論
0/150
提交評論