學生信息管理系統(tǒng)java課程設(shè)計報告含源代碼.doc 免費下載
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、. . . . JAVA程序設(shè)計 課程設(shè)計報告 課 題: 學生信息管理系統(tǒng) 姓 名:學 號:同組:專業(yè)班級:指導(dǎo)教師:設(shè)計時間: 評閱意見: 評定成績: 指導(dǎo)老師簽名: 年 月 日 目 錄一、系統(tǒng)描述21、需要實現(xiàn)的功能32、設(shè)計目的3二、分析與設(shè)計31、功能模塊劃分32、數(shù)據(jù)庫結(jié)構(gòu)描述43、系統(tǒng)詳細設(shè)計文檔64、各個模塊的實現(xiàn)方法描述95、測試數(shù)據(jù)與期望結(jié)果11三、系統(tǒng)測試16四、心得體會23五、參考文獻24六、附錄24一、系統(tǒng)描述1、需現(xiàn)的功
2、能1.1、錄入學生基本信息的功能學生基本信息主要包括:學號、年齡、出生地、專業(yè)、班級總學分,在插入時,如果數(shù)據(jù)庫已經(jīng)存在該學號,則不能再插入該學號。1.2、修改學生基本信息的功能在管理員模式下,只要在表格中選中某個學生,就可以對該學生信息進行修改。1.3、查詢學生基本信息的功能可使用 “”對已存有的學生資料進行查詢。1.4、刪除學生基本信息的功能 在管理員模式下,只要選擇表格中的某個學生,就可以刪除該學生。1.5、用戶登陸用不同的登錄權(quán)限可以進入不同的后臺界面,從而實現(xiàn)權(quán)限操作。1.6、用戶登陸信息設(shè)置可以修改用戶登陸密碼2、設(shè)計目的學生信息管理系統(tǒng)是一個教育單位不可缺少的部分。一個功能齊全、
3、簡單易用的信息管理系統(tǒng)不但能有效地減輕學校相關(guān)工作人員的工作負擔,它的容對于學校的決策者和管理者來說都至關(guān)重要。所以學生信息管理系統(tǒng)應(yīng)該能夠為用戶提供充足的信息和快捷的查詢手段。但一直以來人們使用傳統(tǒng)人工的方式管理文件檔案、統(tǒng)計和查詢數(shù)據(jù),這種管理方式存在著許多缺點,如:效率低、性差、人工的大量浪費;另外時間一長,將產(chǎn)生大量的文件和數(shù)據(jù),這對于查找、更新和維護都帶來了不少困難。隨著科學技術(shù)的不斷提高,計算機科學日漸成熟,其強大的功能已為人們深刻認識,它已進入人類社會的各個領(lǐng)域并發(fā)揮著越來越重要的作用。作為計算機應(yīng)用的一部分,使用計算機對學校的各類信息進行管理,具有手工管理無法比擬的優(yōu)點。例如:
4、檢索迅速、查詢方便、效率高、可靠性好、存儲量大、性好、壽命長、成本低等。這些優(yōu)點能夠極提高學校信息管理的效率,也是一個單位科學化、正規(guī)化管理,與世界接軌的重要條件。本系統(tǒng)是將現(xiàn)代化的計算機技術(shù)和傳統(tǒng)的教學、教務(wù)工作相結(jié)合,按照學院的工作流程設(shè)計完成的。通過一個簡化的學生信息管理系統(tǒng),使學生信息管理工作系統(tǒng)化、規(guī)化、自動化,從而達到提高學生信息管理效率的目的。二、分析與設(shè)計1、功能模塊劃分學生信息管理系統(tǒng)瀏覽學生信息查詢學生信息添加學生信息修改學生信息刪除學生信息普通學生(用戶)模塊班委(管理員)模塊瀏覽學生信息查詢學生信息學生管理登陸管理修改登陸密碼顯示登陸用戶圖1 功能模塊劃分圖2、數(shù)據(jù)庫結(jié)
5、構(gòu)描述2.1、數(shù)據(jù)庫E-R模型 登錄用戶管理賬號密碼職位圖2 登錄用戶管理E-R圖學 生總學分出生地年齡專業(yè)性別XX學號班級圖3 實體學生E-R圖2.2、數(shù)據(jù)庫關(guān)系模型二維表表1 學生表(student)字段數(shù)據(jù)類型說明stuIdnvarchar(30)學號stuNamenvarchar(30)stuSexnvarchar(30)性別stuAgeint年齡stuJgnvarchar(30)籍貫stuZynvarchar(30)專業(yè)classIdnvarchar(30)班號stuSoursenumeric(5,2)總學分圖4 錄入數(shù)據(jù)后的學生表表2 登陸權(quán)限表(login)字段數(shù)據(jù)類型說明use
6、rIdnvarchar(30)用戶名(賬號),即登陸Idpasswordnvarchar(30)登陸密碼positionnvarchar(30)職位,如班委,普通學生圖5 錄入數(shù)據(jù)后的登陸權(quán)限表3、系統(tǒng)詳細設(shè)計文檔3.1、系統(tǒng)執(zhí)行流程圖進度條(閃屏)用戶登陸登陸驗證falsetrue班委(管理員)界面普通學生界面查詢添加修改刪除查詢顯示班委(管理員 )普通學生(用戶)退出退出系統(tǒng)結(jié)束結(jié)束退出系統(tǒng)truefalsefalsetrue修改用戶登陸密碼顯示登陸用戶信息圖6 系統(tǒng)執(zhí)行流程圖3.2、類的劃分表3 學生信息查詢類類名類的成員屬性與方法說明StuQuery.javaJPanel jp1定義一
7、個面板JLabel jp1_jl1定義兩個標簽JTextField jp1_jtf1定義一個文本輸入框utton jp1_1,jp1_2,jp1_3定義三個按鈕JTable jtb定義一個表JScrollPane jsp定義一個滾動面板,用于存放表TableModel tm自定義一個表模型,用于更新表數(shù)據(jù)public StuQuery(Frame Main,String title ,boolean model)構(gòu)造方法,通過傳遞三個參數(shù),實現(xiàn)對話super(Main,title,model)調(diào)用父類的構(gòu)造方法,實現(xiàn)模式對話public void actionPerformed(ActionE
8、vent arg0)事件響應(yīng)方法表4 修改學生信息類類名類的成員屬性與方法說明UpdateStu.javaJLabel jl1,jl2,jl3,jl4,jl5,jl6,jl7,jl8定義八個標簽,用于設(shè)置數(shù)據(jù)庫表的字段名JTextField jtf1,jtf2,jtf3,jtf4,jtf5,jtf6,jtf7,jtf8定義八個文本框,用于接收表的各字段值utton 1,2,3定義三個按鈕,用于事件響應(yīng)public void addView()這是修改學生界面的函數(shù)封裝public AddStu(Frame Main,String title,boolean model)構(gòu)造方法,通過傳遞三個參
9、數(shù),實現(xiàn)對話super(Main,title,model)調(diào)用父類的構(gòu)造方法,實現(xiàn)模式對話public UpdateStu(Frame Main,String title,TableModel tm,int rowNo,boolean model)因為要修改信息,那么必須要獲得所選中的那一行的所有信息,把它們添加到文本框作為默認值,因此構(gòu)造方法還應(yīng)添加一個參數(shù)即傳遞一個模型tm,并傳遞所選中的行號rowpublic void actionPerformed(ActionEvent e)事件響應(yīng)方法表5 修改管理人員信息類類名類的成員屬性與方法說明UpdateLogin.javaJLabel j
10、l1,jl2,jl3定義三個標簽,即用戶名,密碼,職位JTextField jtf1,jtf2,jtf3定義三個文本框,對應(yīng)三個標簽的值utton 1,2,3定義三個按鈕,用于事件響應(yīng)JTable jtb定義一個表格,用于顯示登陸用戶信息PurViewModel pvm自定義登陸用戶信息的數(shù)據(jù)更新模型public void upView()這是修改賬戶信息權(quán)限的界面函數(shù)的封裝public UpdateLogin(Frame Main,String title,PurViewModel pvm,int rowNo,boolean model)因為要修改信息,那么必須要獲得所選中的那一行的所有信息
11、,把它們添加到文本框作為默認值,因此構(gòu)造方法還應(yīng)添加一個參數(shù)即傳遞一個模型tm,并傳遞所選中的行號rowsuper(Main,title,model)調(diào)用父類的構(gòu)造方法,實現(xiàn)模式對話public void actionPerformed(ActionEvent e)事件響應(yīng)方法表6表模式-更新數(shù)據(jù)類名類的成員屬性與方法說明TableModel.javaVector rowData,row,column定義表格所需要的集合(表,行,列)ResultSet rs定義一個記錄集,用于接收從數(shù)據(jù)庫返回來的記錄集SqlConn conn定義一個用于連接數(shù)據(jù)庫的對象,SqlConn是連接數(shù)據(jù)庫的類publ
12、ic TableModel(String sql)構(gòu)造方法,并傳一個SQL語句,實現(xiàn)查詢操作public String getColumnName(int column)這是一個重寫的方法,用于設(shè)置表的列名public int getColumnCount()得到數(shù)據(jù)模型記錄集的列數(shù)public int getRowCount()得到數(shù)據(jù)模型記錄集的行數(shù)public Object getValueAt(int arg0, int arg1)得到數(shù)據(jù)模型記錄集某行某列的值4、各個模塊的實現(xiàn)方法描述說明:此處只包含了個人完成的模塊的實現(xiàn)方法描述4.1、學生信息查詢學生信息查詢窗口,采用了基于管理窗
13、口,即主界面的對話框?qū)崿F(xiàn),實現(xiàn)方法如下:1)定義查詢所需要的面板和組件。2)調(diào)用父類的構(gòu)造方法,實現(xiàn)模式對話。3)進行學生信息查詢。4.2、修改管理人員信息修改管理人員信息的界面,通過模式對話,即繼承JDialog對話框來實現(xiàn)的,實現(xiàn)方法如下:1)定義修改學生信息的相關(guān)組件。2)加載數(shù)據(jù)庫,獲得選中的那一行的所有信息。3)把組件添加到窗體。4)調(diào)用父類的構(gòu)造方法,實現(xiàn)模式對話。5)調(diào)用修改用戶權(quán)限信息的界面的方法。6)修改管理人員信息。7)調(diào)用數(shù)據(jù)庫連接,并設(shè)置操縱更新的sql語句。4.3、修改學生信息修改學生信息的界面,通過模式對話,即繼承JDialog對話框來實現(xiàn),實現(xiàn)方法如下:1)定義修
14、改學生信息的相關(guān)組件。2)加載數(shù)據(jù)庫,獲得選中的那一行的所有信息。3)把組件添加到窗體。4)調(diào)用父類的構(gòu)造方法,實現(xiàn)模式對話。5)調(diào)用修改學生信息的界面的方法。6)修改學生信息。7)完成相應(yīng)功能。4.4、更新數(shù)據(jù)這是一個表模型,用于數(shù)據(jù)更新,實現(xiàn)方法如下:1)定義表格所需要的集合。2)定義一個記錄集,用于接收從數(shù)據(jù)庫返回來的記錄集。3)定義一個用于連接數(shù)據(jù)庫的對象。4)設(shè)置表格的列名。5)創(chuàng)建表的記錄集。6)調(diào)用數(shù)據(jù)庫連接。7)設(shè)置表的列名,并得到表的列數(shù)和行數(shù)。8)得到某行某列的值。5、測試數(shù)據(jù)與期望結(jié)果5.1、學生信息查詢數(shù)據(jù)測試與期望結(jié)果數(shù)據(jù)測試與期望結(jié)果如下圖:圖7為學生登錄后的最初界
15、面;圖8為學生查看所有信息界面;圖9為全部學生的信息記錄(此處同時運用到了TableModel類);圖10則是實現(xiàn)了此處的查詢功能,測試數(shù)據(jù)為: :肖立本 期望結(jié)果將顯示以下數(shù)據(jù):學號:904325 :肖立本 性別:男 年齡:23 出生地: 專業(yè):信息管理 班級:9040303 總學分:542.5圖7 學生信息管理系統(tǒng)圖8 學生信息管理系統(tǒng)-顯示記錄圖9 學生信息管理系統(tǒng)-顯示所有信息圖10 學生信息管理系統(tǒng)-學生信息查詢5.2、修改管理人員數(shù)據(jù)測試與期望結(jié)果數(shù)據(jù)測試與期望結(jié)果如下圖:圖11將顯示出所有管理人員信息。此處測試的數(shù)據(jù)為: 賬號1:admin 密碼1:admin 職位1:班委 賬號
16、2:user 密碼2:user 職位2:普通學生圖12是彈出的修改密碼窗口。此處可將密碼admin修改為其它值。圖11 顯示所有管理人員信息圖12 修改管理人員信息窗口5.3、修改學生信息數(shù)據(jù)測試與期望結(jié)果數(shù)據(jù)測試與期望結(jié)果如下圖:圖13為全部學生的信息記錄(此處同時運用到了TableModel類);圖14是彈出的修改學生信息窗口: 測試數(shù)據(jù):明輝 期望結(jié)果:可修改、性別、年齡、出生地、專業(yè)、班級和總學分。圖13 學生信息管理系統(tǒng)-顯示所有信息圖14 修改學生信息窗口三、系統(tǒng)測試1、系統(tǒng)啟動界面圖15 系統(tǒng)啟動界面2、用戶登錄界面圖16 用戶登錄界面3、班委(管理員)界面,即具有完全權(quán)限的用戶
17、后臺界面圖17 管理員界面4、班委(管理員)界面子菜單項顯示圖18 管理員界面子菜單-系統(tǒng)界面圖19 管理員界面子菜單-學生管理界面圖20 管理員界面子菜單-系統(tǒng)設(shè)置界面5、學生信息查詢界面圖21 學生信息查詢6、學生信息查詢結(jié)果顯示圖22 學生信息查詢顯示7、添加學生信息界面在沒有輸入學號或者,以與某一項時,會彈出一個對話框進行提示,如沒有輸入學號時:圖23 添加學生信息8、修改學生信息界面(學號是主鍵,灰色顯示,即不可更改)圖24 修改學生信息9、顯示所有學生信息圖25 顯示所有信息10、當沒有選中一行的時候,不能修改和刪除,并彈出提示警告框圖26 修改和刪除警告框圖11、刪除文件時的確認
18、對話框(點擊確認時會刪除,點擊取消,則返回主界面)圖27 刪除學生確認對話框12、顯示所有登陸用戶信息圖28 顯示登錄用戶信息示意圖13、修改用戶登陸密碼,選中某個用戶進行修改圖29 修改用戶登錄密碼界面示意圖14、關(guān)閉用戶記錄,即不顯示所有用戶信息圖30 關(guān)閉用戶記錄示意圖15、關(guān)閉學生記錄圖31 關(guān)閉學生記錄示意圖16、退出系統(tǒng)確認對話框只有確認時才會退出系統(tǒng),否則返加主界面圖32 退出系統(tǒng)17、普通學生登陸后的界面(即不能對學生信息進行添加,修改和刪除以與用戶密碼修改,對應(yīng)的這幾項灰色顯示,不可點擊)圖33 學生登錄界面(1)圖34 學生登錄界面(2)四、心得體會這次為期一周的課程設(shè)計讓
19、我對java有了新的認識,首先我接觸了很多上課見過但沒有實際用過的類和方法,讓我對編程有了許多新的思想。 大一學了C語言、C+等,雖然當時學的還不錯,由于學的都是入門知識,所以自己做的程序只能實現(xiàn)一定的功能,和自己平時用的軟件相差很大。這學期剛開課學java,雖然知道這是一門很有用的語言,但是卻感覺沒什么新鮮感,它的跨平臺特性也只是聽聽,根本沒有認識,由于平時學習不刻苦,也沒有時間靜下心來寫過java代碼,當?shù)弥詈笃谀┳詈笠恢軐⑦M行java課程設(shè)計,才靜下心來開始研究java,結(jié)合以前的編程知識,做起了自己的程序。與此同時,我們也在進行數(shù)據(jù)庫課程設(shè)計,和這個系統(tǒng)相類似,做起來比較熟
20、練,同時想通過做課程設(shè)計將數(shù)據(jù)庫和java更好的結(jié)合運用起來,感覺這樣才能夠更貼近實際應(yīng)用。 這次課程設(shè)計使我對java的跨平臺性有了進一步認識,同時加深了課堂上所學到的知識。雖然這是第三次課程設(shè)計,并且自己也有了兩年的上機實驗,但我不得不說這一次課程設(shè)計是前兩次以與任何一節(jié)上機實驗課都不可比的。在課程設(shè)計這一段時間,使我收獲了很多在上機課上無法學習到的知識,尤其是需求分析和eclipse熟練的使用。因為這一部分知識的不熟練,在程序設(shè)計過程中遇到了不少困難,但通過老師的指導(dǎo)和一次又一次的指導(dǎo)、改寫、調(diào)試,將這些困難都解決了,心中的喜悅感油然而生。為了能使程序更加的完善,更加人性化,我也利用了不
21、少的課余時間,查找了各方面的資料,看到一個小型系統(tǒng)能夠展示在電腦屏幕上時,感覺自己這段時間的付出是非常值得的,也使我對java產(chǎn)生了更濃厚的興趣,對自己的學習以與將來的工作都是有很大的幫助的。整個課程設(shè)計過程讓我的java知識得到了應(yīng)用,體驗了程序員編程時的喜怒哀樂,知識、心智,得到全方位提升,收獲頗豐。五、參考文獻著作文獻:1 海廷.Java語言程序設(shè)計教程.:清華大學.20122 印杰,斌,玉強.Java編程案例精解.:電子工業(yè).20053 何梅.java編程實例系列叢書.:清華大學,20024 昭.二級Java語言程序設(shè)計教程.:中國水利水電,20065 文靖.Java程序設(shè)計基礎(chǔ)與上機
22、指導(dǎo).:清華大學,2006 六、附錄1、功能:這是學生信息查詢窗口,采用基于管理窗口,即主界面的對話框?qū)崿F(xiàn)package .View;import java.awt.*;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import javax.swing.*;import .Tools.MyFont;publicclassStuQueryextends JDialog implements ActionListener/定義查詢所需要的面板和組件JPanel jp1;JLabel jp1_jl1;JT
23、extField jp1_jtf1;utton jp1_1,jp1_2,jp1_3;JTable jtb;JScrollPane jsp;TableModel tm;public StuQuery(Frame Main,String title ,boolean model)/調(diào)用父類的構(gòu)造方法,實現(xiàn)模式對話super(Main,title,model);jp1=new JPanel();jp1_jl1=new JLabel("請輸入:");jp1_jl1.setFont(MyFont.f1);jp1_jtf1=new JTextField(15);jp1_1=new ut
24、ton("查 詢->");jp1_1.setFont(MyFont.f1);jp1_1.addActionListener(this);jp1_2=new utton("清 除");jp1_2.setFont(MyFont.f1);jp1_2.addActionListener(this);jp1_3=new utton("顯示所有記錄");jp1_3.setFont(MyFont.f1);jp1_3.addActionListener(this);jp1.add(jp1_jl1);jp1.add(jp1_jtf1);jp1.a
25、dd(jp1_1);jp1.add(jp1_2);jp1.add(jp1_3);jtb=new JTable();jsp=new JScrollPane(jtb);this.add(jp1,"North");this.add(jsp,"Center");this.setSize(600,400);this.setVisible(true);Overridepublicvoid actionPerformed(ActionEvent arg0) / TODO Auto-generated method stub/如果點擊了查詢按鈕if(arg0.getSo
26、urce()=jp1_1)/獲取文本框的值String stuName=jp1_jtf1.getText().trim();/其中trim()是去掉文本框前面可能有的空格,但不能去掉字符串中的空格String sql="select * from student where stuName='"+stuName+"'"/調(diào)用模型tm=new TableModel(sql);jtb.setModel(tm);elseif(arg0.getSource()=jp1_2)jp1_jtf1.setText("");elseif
27、(arg0.getSource()=jp1_3)tm=new TableModel(null);jtb.setModel(tm);2、功能:這是一個表模型,用于更新數(shù)據(jù)package .View;import.SqlConnection.*;/引入數(shù)據(jù)庫連接的包import java.sql.*;import java.util.*;import javax.swing.table.AbstractTableModel;import .SqlConnection.SqlConn;publicclassTableModelextends AbstractTableModel /定義表格所需要的集
28、合VectorrowData,row,column;/定義一個記錄集,用于接收從數(shù)據(jù)庫返回來的記錄集ResultSet rs;/定義一個用于連接數(shù)據(jù)庫的對象SqlConn conn;public TableModel(String sql)if(sql=null)sql="select * from student"/設(shè)置表格的列名column=newVector();column.add("學號");column.add("");column.add("性別");column.add("年齡"
29、);column.add("出生地");column.add("專業(yè)");column.add("班級");column.add("總學分");/創(chuàng)建表的記錄集rowData=newVector();/調(diào)用數(shù)據(jù)庫連接conn=new SqlConn();rs=conn.sqlQuery(sql);try while(rs.next()row=newVector();row.add(rs.getString(1);row.add(rs.getString(2);row.add(rs.getString(3);row.
30、add(rs.getString(4);row.add(rs.getString(5);row.add(rs.getString(6);row.add(rs.getString(7);row.add(rs.getString(8);rowData.add(row); catch (Exception e) e.printStackTrace();/ TODO: handle exceptionOverride/設(shè)置表的列名public String getColumnName(int column) / TODO Auto-generated method stubreturn (String
31、)this.column.get(column);Override/得到的列數(shù)publicint getColumnCount() / TODO Auto-generated method stubreturnthis.column.size();/得到的行數(shù)Overridepublicint getRowCount() / TODO Auto-generated method stubreturnthis.rowData.size();Override/得到某行某列的值public Object getValueAt(int arg0, int arg1) / TODO Auto-gener
32、ated method stubreturn (Vector)this.rowData.get(arg0).get(arg1);3、 功能:這是修改管理人員信息的界面,通過模式對話(即繼承JDialog對話框)來實現(xiàn)package .View;import java.awt.*;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import javax.swing.*;import .SqlConnection.SqlConn;import .Tools.MyFont;publicclassUpdate
33、Loginextends JDialog implements ActionListener /定義修改學生信息的相關(guān)組件JLabel jl1,jl2,jl3;JTextField jtf1,jtf2,jtf3;utton 1,2,3;/這是修改賬戶信息權(quán)限的界面函數(shù)的封裝publicvoidupView()/加載數(shù)據(jù)庫,獲得選中的那一行的所有信息jl1=new JLabel("賬 號:");/因為賬號是主鍵,設(shè)置文本框不可編輯的同時,一般也設(shè)置標簽灰色顯示,以區(qū)別其他標簽 jl1.setEnabled(false);jl1.setBounds(20, 20, 60, 25
34、);jl1.setFont(MyFont.f1);jl2=new JLabel("密 碼:");jl2.setFont(MyFont.f1);jl2.setBounds(250, 20, 60, 25);jl3=new JLabel("職 位:");jl3.setEnabled(false);jl3.setFont(MyFont.f1);jl3.setBounds(20, 60, 60, 25);jtf1=new JTextField(20);/由于賬號是主鍵,因此不能修改,即設(shè)置障礙曙jtf1不可編輯jtf1.setEnabled(false);jtf
35、1.setBounds(70, 20, 130, 25);jtf2=new JTextField(20);jtf2.setBounds(300, 20, 130, 25);jtf3=new JTextField(20);jtf3.setEnabled(false);jtf3.setBounds(70, 60, 130, 25);1=new utton("修 改");1.setFont(MyFont.f1);1.setBounds(100, 100, 80, 25);1.addActionListener(this);2=new utton("取 消");
36、2.setFont(MyFont.f1);2.setBounds(280, 100, 80, 25);2.addActionListener(this);3=new utton("清 除");3.setFont(MyFont.f1);3.setBounds(190,100,80,25);3.addActionListener(this);this.setLayout(null);/把組件添加到窗體this.add(jl1);this.add(jtf1);this.add(jl2);this.add(jtf2);this.add(jl3);this.add(jtf3);thi
37、s.add(1);this.add(2);this.add(3);/因為要修改信息,那么必須要獲得所選中的那一行的所有信息,把它們添加到文本框作為默認值,因此構(gòu)造方法還應(yīng)添加一個參數(shù)即傳遞一個模型tm,并傳遞所選中的行號rowpublic UpdateLogin(Frame Main,String title,PurViewModel pvm,int rowNo,boolean model)/調(diào)用父類的構(gòu)造方法,實現(xiàn)模式對話super(Main,title,model);/調(diào)用修改用戶權(quán)限信息的界面的方法this.upView();/先從表模型中獲取所選中的那一行數(shù)據(jù)String userId
38、=(String)pvm.getValueAt(rowNo, 0);System.out.println("userId="+userId);String password=(String)pvm.getValueAt(rowNo, 1);String position=(String)pvm.getValueAt(rowNo, 2);/設(shè)置廣本框的值jtf1.setText(userId);jtf2.setText(password);jtf3.setText(position);/設(shè)置窗體的屬性this.setSize(465,170);this.setVisible(
39、true);this.setResizable(false);Overridepublicvoid actionPerformed(ActionEvent e) / TODO Auto-generated method stub/當點擊了修改按鈕if(e.getSource()=1)/獲取文本框的信息String userId=jtf1.getText().trim();String password=jtf2.getText().trim();String position=jtf3.getText().trim();/調(diào)用數(shù)據(jù)庫連接/設(shè)置操縱更新的sql語句String sql="
40、;update login set password='"+password+"',position='"+position+"'where userId='"+userId+"'"SqlConn sqlconn=new SqlConn();sqlconn.sqlUpdate(sql);/關(guān)閉交資源sqlconn.closeSqlConn();/關(guān)閉與數(shù)據(jù)庫連接的資源后,再關(guān)閉對話框,否則數(shù)據(jù)不能自動在表中更新顯示出來this.dispose();/如果點擊了取消按鈕,則關(guān)閉模
41、式對話框elseif(e.getSource()=2)this.dispose();/如果點擊了清除按鈕,則清除所有的廣本框的容,除了學號elseif(e.getSource()=3)/由于賬號是主鍵,則不能清空!jtf2.setText("");4、功能:這是修改學生信息的界面,通過模式對話(即繼承JDialog對話框)來實現(xiàn) package .View;import java.awt.*;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import javax.swing.*;
42、import .SqlConnection.SqlConn;import .Tools.MyFont;publicclassUpdateStuextends JDialog implements ActionListener /定義修改學生信息的相關(guān)組件JLabel jl1,jl2,jl3,jl4,jl5,jl6,jl7,jl8;JTextField jtf1,jtf2,jtf3,jtf4,jtf5,jtf6,jtf7,jtf8;utton 1,2,3;intstuAge=0;Double stuSourse=0.0;/這是修改學生信息的界面函數(shù)的封裝publicvoid upView()/加
43、載數(shù)據(jù)庫,獲得選中的那一行的所有信息jl1=new JLabel("學 號:");/因為學號是主鍵,設(shè)置文本框不可編輯的同時,一般也設(shè)置標簽灰色顯示,以區(qū)別其他標簽 jl1.setEnabled(false);jl1.setBounds(20, 20, 60, 25);jl1.setFont(MyFont.f1);jl2=new JLabel("姓 名:");jl2.setFont(MyFont.f1);jl2.setBounds(250, 20, 60, 25);jl3=new JLabel("性 別:");jl3.setFont(
44、MyFont.f1);jl3.setBounds(20, 60, 60, 25);jl4=new JLabel("年 齡:");jl4.setFont(MyFont.f1);jl4.setBounds(250, 60, 60, 25);jl5=new JLabel("出生地:");jl5.setFont(MyFont.f1);jl5.setBounds(14, 100, 60, 25);jl6=new JLabel("專 業(yè):");jl6.setFont(MyFont.f1);jl6.setBounds(20, 140, 60, 25
45、);jl7=new JLabel("班 級:");jl7.setFont(MyFont.f1);jl7.setBounds(20, 180, 60, 25);jl8=new JLabel("總學分:");jl8.setFont(MyFont.f1);jl8.setBounds(240, 180, 60, 25);jtf1=new JTextField(20);/由于學號是主鍵,因此不能修改,即設(shè)置障礙曙jtf1不可編輯jtf1.setEnabled(false);jtf1.setBounds(70, 20, 130, 25);jtf1.setBorder
46、(BorderFactory.createLoweredBevelBorder();jtf2=new JTextField(20);jtf2.setBounds(300, 20, 130, 25);jtf2.setBorder(BorderFactory.createLoweredBevelBorder();jtf3=new JTextField(10);jtf3.setBounds(70, 60, 60, 25);jtf3.setBorder(BorderFactory.createLoweredBevelBorder();jtf4=new JTextField(10);jtf4.setBo
47、unds(300, 60, 60, 25);jtf4.setBorder(BorderFactory.createLoweredBevelBorder();jtf5=new JTextField(30);jtf5.setBounds(70, 100, 360, 25);jtf5.setBorder(BorderFactory.createLoweredBevelBorder();jtf6=new JTextField(20);jtf6.setBounds(70, 140, 290, 25);jtf6.setBorder(BorderFactory.createLoweredBevelBorde
48、r();jtf7=new JTextField(20);jtf7.setBounds(70, 180, 130, 25);jtf7.setBorder(BorderFactory.createLoweredBevelBorder();jtf8=new JTextField(20);jtf8.setBounds(300, 180, 130, 25);jtf8.setBorder(BorderFactory.createLoweredBevelBorder();1=new utton("修 改");1.setFont(MyFont.f1);1.setBounds(100, 22
49、0, 80, 25);1.addActionListener(this);2=new utton("取 消");2.setFont(MyFont.f1);2.setBounds(280, 220, 80, 25);2.addActionListener(this);3=new utton("清 除");3.setFont(MyFont.f1);3.setBounds(190,220,80,25);3.addActionListener(this);this.setLayout(null);/把組件添加到窗體this.add(jl1);this.add(j
50、tf1);this.add(jl2);this.add(jtf2);this.add(jl3);this.add(jtf3);this.add(jl4);this.add(jtf4);this.add(jl5);this.add(jtf5);this.add(jl6);this.add(jtf6);this.add(jl7);this.add(jtf7);this.add(jl8);this.add(jtf8);this.add(1);this.add(2);this.add(3);/因為要修改信息,那么必須要獲得所選中的那一行的所有信息,把它們添加到文本框作為默認值,因此構(gòu)造方法還應(yīng)添加一個參數(shù)即傳遞一個模型tm,并傳遞所選中的行號rowpublic UpdateStu(Frame Main,String title,TableModel tm,int rowNo,boolean model)/調(diào)用父類的構(gòu)造方法,實現(xiàn)模式對話super(Main,title,model);/調(diào)用修改學生信息的界面的方法this.upView();/先從表模型中獲取所選中的那一行數(shù)據(jù)String stuId=(String)tm.getValueAt(rowNo, 0);System.out.println("sutId="+stuId);String stuName=(S
溫馨提示
- 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. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年稅務(wù)局信息技術(shù)服務(wù)外包合同版B版
- 個人商鋪租賃協(xié)議范本2024年版A版
- 2、3、4的乘法口訣說課稿(說課稿)-2024-2025學年二年級上冊數(shù)學人教版
- 2025年度三人房地產(chǎn)合作開發(fā)協(xié)議書范本3篇
- 職業(yè)學院學生轉(zhuǎn)專業(yè)申請表
- 2024年礦石勘探技術(shù)服務(wù)合同版B版
- 福建省南平市五夫中學2020-2021學年高三地理上學期期末試題含解析
- 福建省南平市渭田中學2021-2022學年高三數(shù)學理聯(lián)考試卷含解析
- 2024年行政報告模板制作與市場反饋服務(wù)合同3篇
- 2024年長途汽車運輸協(xié)議
- 2025年江蘇建筑安全員A證考試題庫及答案
- 2024年員工簡單個人總結(jié)
- 2025屆遼寧省沈陽市高三上學期一模英語試卷含答案
- 2024年南京市第一醫(yī)院分院高層次衛(wèi)技人才招聘筆試歷年參考題庫頻考點附帶答案
- 2025年高考歷史復(fù)習之小題狂練300題(選擇題):秦漢時期(20題)
- 熱電站汽輪機發(fā)電安全操作規(guī)程(2篇)
- 2024年WPS計算機二級考試題庫350題(含答案)
- 2024年首都機場集團招聘筆試參考題庫附帶答案詳解
- 井下軌道鋪設(shè)標準
- 新版PEP人教版小學英語六年級上、下冊單詞表(共6頁)
- 鋼便橋施工專項方案(一)(型鋼縱梁)
評論
0/150
提交評論