版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 《數(shù)據(jù)庫(kù)原理及應(yīng)用》</p><p><b> 課</b></p><p><b> 程</b></p><p><b> 設(shè)</b></p><p><b> 計(jì)</b></p><p><b&
2、gt; 報(bào)</b></p><p><b> 告</b></p><p><b> 一、設(shè)計(jì)目的 </b></p><p> 《數(shù)據(jù)庫(kù)原理及應(yīng)用》是一門(mén)實(shí)踐性很強(qiáng)的課程,為了學(xué)好這門(mén)課程,必須在掌握理論知識(shí)的同時(shí),加強(qiáng)上機(jī)實(shí)踐。本課程設(shè)計(jì)的主要目的在于:</p><p> 1、
3、加深對(duì)數(shù)據(jù)庫(kù)基礎(chǔ)理論和基本知識(shí)的理解,培養(yǎng)學(xué)生運(yùn)用所學(xué)理論知識(shí)對(duì)數(shù)據(jù)庫(kù)進(jìn)行組織、管理和使用的能力。 </p><p> 2、掌握數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)的整個(gè)設(shè)計(jì)過(guò)程(包括需求分析、概念結(jié)構(gòu)設(shè)計(jì)、邏輯結(jié)構(gòu)設(shè)計(jì)與物理設(shè)計(jì)與實(shí)施),提高運(yùn)用數(shù)據(jù)庫(kù)解決實(shí)際問(wèn)題的能力。 </p><p><b> 二、設(shè)計(jì)要求</b></p><p> 1、要求學(xué)生熟練掌
4、握相關(guān)數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí),獨(dú)立完成設(shè)計(jì)任務(wù),并完成課程設(shè)計(jì)報(bào)告。</p><p> 2、學(xué)生必須仔細(xì)研讀數(shù)據(jù)庫(kù)課程設(shè)計(jì)任務(wù)書(shū),課程設(shè)計(jì)以學(xué)生自學(xué)為主、指導(dǎo)教師指導(dǎo)為輔。</p><p> 3、本次課程設(shè)計(jì)按照教學(xué)要求需要在一周半時(shí)間內(nèi)獨(dú)立完成,學(xué)生要發(fā)揮自主學(xué)習(xí)的能力,充分利用時(shí)間,安排好課設(shè)的時(shí)間計(jì)劃,并在課設(shè)過(guò)程中不斷檢測(cè)自己的計(jì)劃完成情況,及時(shí)地向指導(dǎo)教師匯報(bào)。</p>
5、<p> 4、使用工具不限,可以使用.net C#、Delphi、PB、VB等。</p><p> 5、可以做成C/S或者B/S。</p><p> 6、使用軟件工程的思想和方法進(jìn)行工程設(shè)計(jì)。</p><p><b> 三、設(shè)計(jì)任務(wù)</b></p><p><b> 學(xué)生成績(jī)管理系統(tǒng)&l
6、t;/b></p><p> 該系統(tǒng)至少應(yīng)包含如下功能:</p><p><b> 1、身份驗(yàn)證模塊</b></p><p> 進(jìn)入系統(tǒng)時(shí)首先進(jìn)行身份驗(yàn)證。只有用戶名和密碼正確才能進(jìn)入系統(tǒng)。若身</p><p> 份驗(yàn)證時(shí)間超過(guò)20秒則停止身份驗(yàn)證。</p><p><b>
7、; 2、用戶管理</b></p><p> 對(duì)使用本系統(tǒng)的用戶進(jìn)行添加、查詢、修改密碼、刪除等操作。</p><p><b> 3、學(xué)生信息錄入</b></p><p> 本系統(tǒng)能夠錄入學(xué)生的學(xué)號(hào)、姓名、性別、班級(jí)等信息,并且能夠判斷是否有不符合信息項(xiàng),如有不符合的則給出提示。</p><p><
8、;b> 4、學(xué)生成績(jī)查詢</b></p><p> 可以根據(jù)學(xué)號(hào)、姓名、班級(jí)、學(xué)期等信息項(xiàng)中的一項(xiàng)或多項(xiàng)的組合,進(jìn)行模糊查詢和精確查詢,從而高效地找到您想要的信息。</p><p><b> 5、學(xué)生成績(jī)更新</b></p><p> 可以根據(jù)學(xué)號(hào)、姓名等信息項(xiàng)中的一項(xiàng),進(jìn)行模糊查詢和精確查詢,找到要修改的學(xué)生記錄,最
9、后是對(duì)單個(gè)記錄進(jìn)行逐個(gè)的修改。也可以把錄錯(cuò)或不再有用的信息刪除掉。</p><p><b> 6、學(xué)生成績(jī)排序</b></p><p> 可以按照學(xué)號(hào)、姓名、性別、班級(jí)、成績(jī)的升序/降序(包括各科成績(jī)、總分、平均分)來(lái)進(jìn)行排序。</p><p><b> 7、統(tǒng)計(jì) </b></p><
10、p> 可以按照課程、班級(jí)、專業(yè)等進(jìn)行統(tǒng)計(jì),形成報(bào)表。 </p><p><b> 學(xué)生自選課題</b></p><p> 學(xué)生原則上可以結(jié)合個(gè)人愛(ài)好自選課題,要求自選課題必須覆蓋數(shù)據(jù)庫(kù)的主要內(nèi)容,有一定的深度與難度,。學(xué)生自選課題需提前報(bào)課程設(shè)計(jì)指導(dǎo)教師批準(zhǔn)方可生效。</p><p><b> 四、成績(jī)考核<
11、/b></p><p> 根據(jù)完成任務(wù)的情況(必須進(jìn)行系統(tǒng)驗(yàn)收 + 答辯)、課程設(shè)計(jì)報(bào)告書(shū)的質(zhì)量和課程設(shè)計(jì)過(guò)程中的工作態(tài)度等按照50%、30%、20%加權(quán)綜合打分。成績(jī)?cè)u(píng)定實(shí)行優(yōu)秀、良好、中等、及格和不及格五個(gè)等級(jí)。</p><p><b> 五、設(shè)計(jì)報(bào)告</b></p><p> 1、主要內(nèi)容及裝訂順序:封面(封面用學(xué)校的統(tǒng)一封面
12、)、目錄、正文、參考文獻(xiàn)、附錄等。</p><p> 2、正文部分應(yīng)該包括:需求分析、總體設(shè)計(jì)、數(shù)據(jù)庫(kù)設(shè)計(jì)(含概念設(shè)計(jì)、邏輯設(shè)計(jì)、物理設(shè)計(jì),設(shè)計(jì)報(bào)告要有ER圖。)、程序模塊設(shè)計(jì)(含功能需求、用戶界面設(shè)計(jì)、程序代碼設(shè)計(jì)與分析、運(yùn)行結(jié)果)等。</p><p> 3、不交設(shè)計(jì)報(bào)告或抄襲者,按不及格論。</p><p><b> 六、指導(dǎo)教師</b&g
13、t;</p><p> 計(jì)05: 杜獻(xiàn)峰 高艷霞</p><p> 計(jì)06: 杜獻(xiàn)峰 徐飛</p><p><b> 正文 </b></p><p><b> 需求分析:</b></p><p><b> 身份驗(yàn)證模塊</b></
14、p><p> 此程序要求允許不同級(jí)別的用戶登錄,級(jí)別不同,擁有的權(quán)限不同,可以進(jìn)行的操作亦不同。進(jìn)入系統(tǒng)時(shí)首先進(jìn)行身份驗(yàn)證。只有用戶名和密碼正確才能進(jìn)入系統(tǒng)。若身份驗(yàn)證時(shí)間超過(guò)20秒則停止身份驗(yàn)證。</p><p><b> 2、用戶管理</b></p><p> 對(duì)使用本系統(tǒng)的用戶進(jìn)行添加、查詢、修改密碼、刪除等操作。其中,管理員權(quán)限的可以
15、執(zhí)行全部操作,普通用戶登錄時(shí)不允許查詢用戶,用戶添加時(shí)通過(guò)程序只能添加普通類型的用戶。</p><p><b> 3、學(xué)生信息錄入</b></p><p> 本系統(tǒng)能夠錄入學(xué)生的學(xué)號(hào)、姓名、性別、班級(jí)等信息,并且能夠判斷是否有不符合信息項(xiàng),如有不符合的則給出提示。</p><p><b> 4、學(xué)生成績(jī)查詢</b>&
16、lt;/p><p> 可以根據(jù)學(xué)號(hào)、姓名、班級(jí)、學(xué)期等信息項(xiàng)中的一項(xiàng)或多項(xiàng)的組合,進(jìn)行模糊查詢和精確查詢,從而高效地找到您想要的信息。</p><p><b> 5、學(xué)生成績(jī)更新</b></p><p> 可以根據(jù)學(xué)號(hào)、姓名等信息項(xiàng)中的一項(xiàng),進(jìn)行模糊查詢和精確查詢,找到要修改的學(xué)生記錄,最后是對(duì)單個(gè)記錄進(jìn)行逐個(gè)的修改。也可以把錄錯(cuò)或不再有用的
17、信息刪除掉。</p><p><b> 6、學(xué)生成績(jī)排序</b></p><p> 可以按照學(xué)號(hào)、姓名、性別、班級(jí)、成績(jī)的升序/降序(包括各科成績(jī)、總分、平均分)來(lái)進(jìn)行排序。</p><p><b> 7、統(tǒng)計(jì) </b></p><p> 可以按照課程、班級(jí)、專業(yè)等進(jìn)行統(tǒng)計(jì),形成
18、報(bào)表。</p><p><b> 總體設(shè)計(jì):</b></p><p> 系統(tǒng)總體框架采用Frame框架,將主frame用分隔符分成左右兩部分,左半部分設(shè)置一導(dǎo)航(用Tree控件實(shí)現(xiàn)),右半部分使用Panel卡片布局,右半部分共設(shè)置了9個(gè)Panel,分別實(shí)現(xiàn)用戶登錄后的歡迎界面,用戶添加界面,用戶查詢界面,用戶修改界面,學(xué)生信息添加界面,分?jǐn)?shù)查詢界面,分?jǐn)?shù)排序界面,
19、分?jǐn)?shù)修改添加刪除界面,信息統(tǒng)計(jì)界面。點(diǎn)擊左側(cè)的葉子節(jié)點(diǎn),在右側(cè)顯示相對(duì)應(yīng)的Panel。程序另外單獨(dú)添加一個(gè)OracleSQL類,在此類定義所有的需要操作數(shù)據(jù)庫(kù)的函數(shù),各個(gè)頁(yè)面需要調(diào)用數(shù)據(jù)庫(kù)時(shí),只需要調(diào)用此類中的函數(shù)就可以了,這樣就將界面和數(shù)據(jù)處理分開(kāi)在不同的類中,是代碼更易可讀和修改,增加或者修改功能時(shí)只需修改SQL語(yǔ)句就可以了。</p><p><b> 數(shù)據(jù)庫(kù)設(shè)計(jì):</b></p
20、><p> 此程序按照要求使用的是Oracle數(shù)據(jù)庫(kù)。程序共設(shè)計(jì)了4張表,分別是用戶表,學(xué)生信息表,課程信息表,學(xué)生成績(jī)表。</p><p><b> ER圖設(shè)計(jì)</b></p><p><b> m</b></p><p> n
21、 </p><p> 由ER圖轉(zhuǎn)化為關(guān)系:</p><p> USERMANAGER(username,password,type)</p><p> STUDENT(cno,sn
22、ame,ssex,sage,sdept,sclass,sspec)</p><p> SC(cno,cname,grade,term)</p><p> 在數(shù)據(jù)庫(kù)中創(chuàng)建的表實(shí)際如下:</p><p><b> 四:程序模塊設(shè)計(jì)、</b></p><p><b> 登錄模塊設(shè)計(jì):</b><
23、;/p><p> 登錄窗體使用Frame,在Frame里添加兩個(gè)JTable用于提示輸入信息,兩個(gè)編輯框用于輸入用戶名和密碼,兩個(gè)單選按鈕用于選擇用戶登錄類型,兩個(gè)按鈕用于確認(rèn)和取消,一個(gè)JTable用于顯示限制用戶登錄時(shí)間,效果圖如下:</p><p> 其中設(shè)計(jì)倒計(jì)時(shí)模塊代碼:</p><p> 在UserLogin類中定義兩個(gè)Timer類型的變量</p
24、><p> Timer secondTime2 = new Timer(1000,this);/*將定時(shí)器設(shè)定為每秒執(zhí)行一次actionPerformed的方法*/ </p><p> Timer secondTime = new Timer(20000,this);/*將定時(shí)器設(shè)定為每秒執(zhí)行一次actionPerformed的方法*/</p><p> 在
25、UserLogin類的構(gòu)造函數(shù)中啟動(dòng)這兩個(gè)定時(shí)器變量</p><p> secondTime.start();/*定時(shí)器啟動(dòng)*/ secondTime2.start();/*定時(shí)器啟動(dòng)*/</p><p><b> 在監(jiān)聽(tīng)其中進(jìn)行監(jiān)聽(tīng)</b></p><p> if(e.getSource()==secondTime){</
26、p><p> System.exit(0);</p><p><b> }</b></p><p> else if(e.getSource()==secondTime2){ </p><p> label1.setText("登錄倒數(shù)計(jì)時(shí) : "+n--+" s");
27、</p><p><b> }</b></p><p><b> 用戶登錄驗(yàn)證模塊:</b></p><p> 首先連接數(shù)據(jù)庫(kù),連接上數(shù)據(jù)庫(kù)后查詢Usermanager表,若能查到,返回true,允許登錄,調(diào)用主頁(yè)面,同時(shí)計(jì)時(shí)器停止,將登錄窗口隱藏。</p><p> OracleSQL o
28、racle = new OracleSQL();</p><p> if(oracle.ConnectSQL(name, pwd, type)){</p><p> StudentSystem studentSystem = new StudentSystem(type);</p><p> secondTime.stop();</p><
29、p> secondTime2.stop();</p><p> this.setVisible(false);</p><p><b> 主系統(tǒng)頁(yè)面設(shè)計(jì):</b></p><p> 主頁(yè)面分左右兩塊,左面為樹(shù)控件,左邊為各功能顯示頁(yè)面,效果圖如下:</p><p><b> 樹(shù)控件模塊設(shè)計(jì):&l
30、t;/b></p><p> 在StudentSystem類中定義葉子節(jié)點(diǎn)</p><p> private DefaultMutableTreeNode stRoot =</p><p> new DefaultMutableTreeNode(new MyNode("操作選項(xiàng)","0"));</p>
31、<p> private DefaultMutableTreeNode st1 =</p><p> new DefaultMutableTreeNode(new MyNode("用戶管理","1"));</p><p> private DefaultMutableTreeNode st2 =</p><p&g
32、t; new DefaultMutableTreeNode(new MyNode("學(xué)生信息管理","2"));</p><p> private DefaultMutableTreeNode st3 =</p><p> new DefaultMutableTreeNode(new MyNode("學(xué)生成績(jī)查詢",&quo
33、t;3"));</p><p> private DefaultMutableTreeNode st4 =</p><p> new DefaultMutableTreeNode(new MyNode("更新","4"));</p><p> private DefaultMutableTreeNode st5
34、 =</p><p> new DefaultMutableTreeNode(new MyNode("學(xué)生成績(jī)排序","5"));</p><p> private DefaultMutableTreeNode st6 =</p><p> new DefaultMutableTreeNode(new MyNode(&q
35、uot;統(tǒng)計(jì)","6"));</p><p> private DefaultMutableTreeNode st11 =</p><p> new DefaultMutableTreeNode(new MyNode("用戶添加","11"));</p><p> private Defau
36、ltMutableTreeNode st12 =</p><p> new DefaultMutableTreeNode(new MyNode("用戶查詢","12"));</p><p> private DefaultMutableTreeNode st13 =</p><p> new DefaultMutable
37、TreeNode(new MyNode("修改密碼","13"));</p><p> private DefaultMutableTreeNode st21 =</p><p> new DefaultMutableTreeNode(new MyNode("學(xué)生信息錄入","21"));</p>
38、;<p> private DefaultMutableTreeNode st31 =</p><p> new DefaultMutableTreeNode(new MyNode("查詢成績(jī)","31"));</p><p> private DefaultMutableTreeNode st32 =</p>&l
39、t;p> new DefaultMutableTreeNode(new MyNode("按學(xué)號(hào)+班級(jí)查詢","32"));</p><p> private DefaultMutableTreeNode st41 =</p><p> new DefaultMutableTreeNode(new MyNode("學(xué)生成績(jī)更新&q
40、uot;,"41"));</p><p> private DefaultMutableTreeNode st51 =</p><p> new DefaultMutableTreeNode(new MyNode("升序","51"));</p><p> private DefaultMutable
41、TreeNode st52 =</p><p> new DefaultMutableTreeNode(new MyNode("降序","52"));</p><p> 其中MyNode是定義的一個(gè)內(nèi)部類,其構(gòu)造函數(shù)public MyNode(String values,String id){</p><p> this
42、.values=values;</p><p> this.id=id;</p><p><b> }</b></p><p> 通過(guò)id值可以確定單擊的是哪一個(gè)節(jié)點(diǎn)。</p><p> 構(gòu)造樹(shù)的時(shí)候根據(jù)登錄用戶的類型的不同為樹(shù)添加不同的葉子節(jié)點(diǎn)。以此來(lái)實(shí)現(xiàn)不同的用戶擁有不同的功能。</p><
43、;p><b> 構(gòu)造樹(shù)的函數(shù):</b></p><p> public void initialTree(int login_id){</p><p> if(login_id==0){</p><p> st1.add(st12);</p><p><b> }</b></p
44、><p> stRoot.add(st1);</p><p> stRoot.add(st2);</p><p> stRoot.add(st3);</p><p> stRoot.add(st4);</p><p> stRoot.add(st5);</p><p> stRoot.a
45、dd(st6);</p><p> st1.add(st11);</p><p> st1.add(st13);</p><p> st2.add(st21);</p><p> st3.add(st31);</p><p> st3.add(st32);</p><p> st4.
46、add(st41);</p><p> st5.add(st51);</p><p> st5.add(st52);</p><p><b> }</b></p><p> 定義各個(gè)功能模版類的對(duì)象</p><p> public void initialPanel(){</p&g
47、t;<p> welcome = new Welcome();</p><p> useradd = new UserAdd();</p><p> userchangePwd = new UserChangePwd();</p><p> userquery= new UserQuery();</p><p> ne
48、wstudentadd= new NewStudentAdd();</p><p> gradequery= new GradeQuery();</p><p> graderank = new GradeRank();</p><p> gradeupdate= new GradeUpdate();</p><p> statist
49、ical= new Statistical();</p><p><b> }</b></p><p><b> 初始化右半邊的模版</b></p><p> public void initialJpy(){</p><p> jpy.setLayout(new CardLayout())
50、;</p><p> cl = (CardLayout)jpy.getLayout();</p><p> jpy.add(welcome,"welcome");</p><p> jpy.add(useradd,"useradd");</p><p> jpy.add(userchangePw
51、d,"userchangePwd");</p><p> jpy.add(userquery,"userquery");</p><p> jpy.add(newstudentadd,"newstudentadd");</p><p> jpy.add(gradequery,"gradequ
52、ery");</p><p> jpy.add(graderank,"graderank");</p><p> jpy.add(gradeupdate,"gradeupdate");</p><p> jpy.add(statistical,"statistical");</p&g
53、t;<p><b> }</b></p><p> 在監(jiān)聽(tīng)函數(shù)中根據(jù)不同的節(jié)點(diǎn)響應(yīng)對(duì)應(yīng)的面板</p><p> public void addListener(){</p><p> jt.addMouseListener(</p><p> new MouseAdapter(){</p&g
54、t;<p> public void mouseClicked(MouseEvent e){</p><p> DefaultMutableTreeNode dmtntemp= </p><p> (DefaultMutableTreeNode)jt.getLastSelectedPathComponent();</p><p> MyNode
55、 mynode = (MyNode)dmtntemp.getUserObject();</p><p> String id = mynode.getId();</p><p> if(id.equals("0")){</p><p> cl.show(jpy, "welcome");</p><p&
56、gt; System.out.println("歡迎頁(yè)面");</p><p><b> }</b></p><p> else if(id.equals("11")){</p><p> cl.show(jpy, "useradd");</p><p>
57、;<b> }</b></p><p> else if(id.equals("12")){</p><p> cl.show(jpy, "userquery");</p><p> //userquery.setVisible(true);</p><p><b&g
58、t; }</b></p><p> else if(id.equals("13")){</p><p> cl.show(jpy, "userchangePwd");</p><p> //userchangePwd.setVisible(true);</p><p> userc
59、hangePwd.setFocus();</p><p><b> }</b></p><p> else if(id.equals("21")){</p><p> cl.show(jpy, "newstudentadd");</p><p><b> }<
60、;/b></p><p> else if(id.equals("31")){</p><p> //gradequery.setVisible(true);</p><p> cl.show(jpy, "gradequery");</p><p><b> }</b>
61、;</p><p> else if(id.equals("41")){</p><p> //gradeupdate.setVisible(true);</p><p> cl.show(jpy, "gradeupdate");</p><p><b> }</b><
62、;/p><p> else if(id.equals("51")){</p><p> //graderank.setVisible(true);</p><p> cl.show(jpy, "graderank");</p><p><b> }</b></p>
63、<p> else if(id.equals("6")){</p><p> //graderank.setVisible(true);</p><p> cl.show(jpy, "statistical");</p><p><b> }</b></p><p&
64、gt;<b> }</b></p><p><b> }</b></p><p><b> );</b></p><p> jt.setToggleClickCount(1);//將展開(kāi)節(jié)點(diǎn)的鼠標(biāo)點(diǎn)擊次數(shù)設(shè)置為1</p><p><b> }&
65、lt;/b></p><p><b> 設(shè)計(jì)操作數(shù)據(jù)庫(kù)類:</b></p><p> 對(duì)數(shù)據(jù)庫(kù)的連接,數(shù)據(jù)的查詢,更新函數(shù)都寫(xiě)在這一個(gè)類中。</p><p> 連接數(shù)據(jù)庫(kù)函數(shù):連接成功則返回true,否則返回false;</p><p> public boolean ConnectSQL(){//連接數(shù)據(jù)
66、庫(kù)</p><p> if(stmt!=null){</p><p><b> try {</b></p><p> stmt.close();</p><p> } catch (SQLException e) {</p><p> // TODO Auto-generated cat
67、ch block</p><p> e.printStackTrace();</p><p><b> }</b></p><p><b> }</b></p><p> if(conn!=null){</p><p><b> try {</b&g
68、t;</p><p> conn.close();</p><p> } catch (SQLException e) {</p><p> // TODO Auto-generated catch block</p><p> e.printStackTrace();</p><p><b> }
69、</b></p><p><b> }</b></p><p><b> try { </b></p><p> /** 使用Class.forName()方法自動(dòng)創(chuàng)建這個(gè)驅(qū)動(dòng)程序的實(shí)例且自動(dòng)調(diào)用DriverManager來(lái)注冊(cè)它*/</p><p> Class.forName
70、(DB_DRIVER).newInstance(); </p><p> //與url指定的數(shù)據(jù)源建立連接 </p><p> conn = DriverManager.getConnection(DB_URL, DB_User, DB_Pwd); </p><p> //采用Statement進(jìn)行查詢 </p><p> stmt
71、= conn.createStatement(); </p><p> System.out.println("連接成功");</p><p> return true;</p><p> } catch (Exception e) { </p><p> e.printStackTrace(); </p&g
72、t;<p> return false;</p><p><b> } </b></p><p><b> }</b></p><p><b> 驗(yàn)證用戶登錄函數(shù):</b></p><p><b> //驗(yàn)證用戶登錄</b><
73、/p><p> public boolean ConnectSQL(String username,String userpassword,int usertype) throws SQLException{</p><p> String sql="select *from USERMANAGER where" +</p><p> &quo
74、t; USERNAME='"+username+"'and PASSWORD='"+userpassword+"'and TYPE='"+usertype+"'";</p><p> if(ConnectSQL()){</p><p> //System.out.pri
75、ntln("連接成功");</p><p> return execute(sql);</p><p><b> }</b></p><p><b> else </b></p><p> return false; </p><p><
76、;b> }</b></p><p> //執(zhí)行查詢 驗(yàn)證登陸</p><p> public boolean execute(String sql) throws SQLException{</p><p> boolean is_login =false;</p><p><b> try{</b
77、></p><p> rs = stmt.executeQuery(sql);</p><p> }catch (SQLException e) { </p><p> e.printStackTrace(); </p><p><b> } </b></p><p> if(rs
78、.next())</p><p> is_login=true;</p><p> rs.close();</p><p><b> close();</b></p><p> return is_login;</p><p><b> }</b></p>
79、;<p> 數(shù)據(jù)查詢函數(shù),其中把查詢到的數(shù)據(jù)用Vector保存。</p><p> public boolean executeQuery(String sql) throws SQLException { //數(shù)據(jù)查詢</p><p> if(!ConnectSQL())</p><p> return false;</p>&
80、lt;p> rs = null; </p><p> columnHeads=new Vector();</p><p> Rows=new Vector();</p><p><b> try { </b></p><p> rs = stmt.executeQuery(sql); </p>
81、<p> } catch (SQLException e) { </p><p> e.printStackTrace(); </p><p> return false;</p><p><b> } </b></p><p> if(!rs.next()){</p><p&
82、gt; rs.close();</p><p><b> close();</b></p><p> return false;</p><p><b> }</b></p><p><b> try{</b></p><p> Result
83、SetMetaData rsmd = rs.getMetaData();</p><p> for(int i =1;i<=rsmd.getColumnCount();i++)</p><p> columnHeads.addElement(rsmd.getColumnName(i));//得到列的頭</p><p><b> do{</
84、b></p><p> Rows.addElement(getNextRow(rs,rsmd));</p><p> }while(rs.next());</p><p> rs.close();</p><p> return true;</p><p> }catch(SQLException e)
85、{</p><p> e.printStackTrace();</p><p> return false;</p><p><b> }</b></p><p> // return true;</p><p><b> }</b></p><
86、p> private Vector getNextRow(ResultSet rs,ResultSetMetaData rsmd)</p><p> throws SQLException{</p><p> Vector currentRow = new Vector();//用于存放每行的記錄</p><p> for(int i =1;i<
87、=rsmd.getColumnCount();++i)</p><p> currentRow.addElement(rs.getString(i));</p><p> return currentRow;</p><p><b> }</b></p><p><b> 數(shù)據(jù)更新函數(shù):</b&g
88、t;</p><p> public boolean executeUpdate(String sql){//數(shù)據(jù)更新</p><p> if(!ConnectSQL())</p><p> return false;</p><p><b> try { </b></p><p> s
89、tmt.executeUpdate(sql);</p><p><b> close();</b></p><p> return true;</p><p> } catch (SQLException e) { </p><p> e.printStackTrace(); </p><p&
90、gt; return false;</p><p><b> }</b></p><p> //return true;</p><p><b> }</b></p><p><b> 用戶添加頁(yè)面設(shè)計(jì):</b></p><p> 在程序中添
91、加用戶只允許添加普通用戶。</p><p><b> 頁(yè)面設(shè)計(jì)圖如下</b></p><p> 在確認(rèn)按鈕的監(jiān)聽(tīng)里面添加代碼如下</p><p> String user_name=jtf.getText().trim();</p><p> String user_pwd = jpwdfArray[0].get
92、Text().trim();</p><p> String user_pwd2 = jpwdfArray[1].getText().trim();</p><p> if(user_name.equals("")||user_pwd.equals("")||user_pwd2.equals("")){</p>
93、<p> JOptionPane.showMessageDialog(this,"用戶名或密碼不能為空");</p><p><b> return;</b></p><p><b> }</b></p><p> if(!user_pwd.equals(user_pwd2)){<
94、;/p><p> JOptionPane.showMessageDialog(this,"兩次輸入的密碼不一致");</p><p><b> return;</b></p><p><b> }</b></p><p> String type ="1"
95、;</p><p> sql="insert into usermanager values('"+user_name+"','"+user_pwd+"','"+type+"')";</p><p> if(oracle.executeUpdate(sql))
96、{</p><p> JOptionPane.showMessageDialog(this,"添加成功"); </p><p> System.out.println("插入成功");</p><p><b> return;</b></p><p>&
97、lt;b> }</b></p><p><b> else{</b></p><p> JOptionPane.showMessageDialog(this,"該用戶名已存在"); </p><p> System.out.println("插入失敗");&
98、lt;/p><p><b> return;</b></p><p><b> }</b></p><p><b> 用戶查詢頁(yè)面設(shè)計(jì):</b></p><p> 在編輯框中若輸入為空則查詢?nèi)?,否則查詢指定用戶</p><p><b>
99、 設(shè)計(jì)頁(yè)面如下:</b></p><p> 當(dāng)監(jiān)聽(tīng)器監(jiān)聽(tīng)到查詢按鈕時(shí),添加的代碼如下</p><p> String stu_id=jtf.getText().trim();</p><p> OracleSQL oracle1= new OracleSQL();</p><p> String sql=null;<
100、/p><p> if(stu_id.equals(""))//查詢?nèi)?lt;/p><p><b> {</b></p><p> sql="select *from turing.usermanager";</p><p><b> }<
101、;/b></p><p><b> else</b></p><p><b> {</b></p><p> sql="select *from turing.usermanager where username like '"+stu_id+"'%";&
102、lt;/p><p><b> }</b></p><p><b> try {</b></p><p> if(!oracle1.executeQuery(sql)){</p><p> JOptionPane.showMessageDialog(this,"未查詢到結(jié)果",
103、"",</p><p> JOptionPane.ERROR_MESSAGE);</p><p><b> return;</b></p><p><b> }</b></p><p> } catch (HeadlessException | SQLException
104、e1) {</p><p> // TODO Auto-generated catch block</p><p> e1.printStackTrace();</p><p><b> }</b></p><p> v_data=oracle1.Rows;</p><p> v_hea
105、d=oracle1.columnHeads;</p><p><b> //更新表格模型</b></p><p> DefaultTableModel dtm=new DefaultTableModel(v_data,v_head);</p><p> jt.setModel(dtm);</p><p> //更
106、新顯示((DefaultTableModel)jt.getModel()).fireTableStructureChanged();</p><p><b> 用戶修改頁(yè)面設(shè)計(jì):</b></p><p><b> 界面設(shè)計(jì)圖如下:</b></p><p> 在確認(rèn)按鈕的監(jiān)聽(tīng)函數(shù)中添加代碼如下</p&
107、gt;<p> String user_name=jtf.getText().trim();</p><p> String user_pwd = jpfArray[0].getText().trim();</p><p> String user_pwdnew = jpfArray[1].getText().trim();</p><p>
108、String user_pwdnew2 = jpfArray[2].getText().trim();</p><p> String type ="1";</p><p> if(user_name.equals("")||user_pwd.equals("")||user_pwdnew.equals(""
109、;)||user_pwdnew.equals("")){</p><p> JOptionPane.showMessageDialog(this,"用戶名和密碼不能為空","",</p><p> JOptionPane.ERROR_MESSAGE);</p><p><b> return
110、;</b></p><p><b> }</b></p><p> if(!user_pwdnew.equals(user_pwdnew2)){</p><p> JOptionPane.showMessageDialog(this,"兩次輸入的密碼不一致");</p><p>&l
111、t;b> return;</b></p><p><b> }</b></p><p> sql="update usermanager set password='"+user_pwdnew+"'where username='"+user_name+"'&qu
112、ot;;</p><p> if(oraclesql.executeUpdate(sql)){</p><p> System.out.println("修改成功");</p><p> JOptionPane.showMessageDialog(this,"修改成功","",</p>
113、<p> JOptionPane.ERROR_MESSAGE);</p><p><b> return;</b></p><p><b> }</b></p><p><b> else{</b></p><p> System.out.pri
114、ntln("修改失敗");</p><p> JOptionPane.showMessageDialog(this,"修改失敗","",</p><p> JOptionPane.ERROR_MESSAGE);</p><p><b> return;</b></p>
115、<p><b> }</b></p><p> 學(xué)生信息添加頁(yè)面設(shè)計(jì):</p><p><b> 該頁(yè)面設(shè)計(jì)圖如下:</b></p><p> 提交按鈕監(jiān)聽(tīng)消息的核心代碼如下</p><p> sql="insert into turing.student valu
116、es" +</p><p> "('"+std_id+"','"+std_name+"','"+std_sex+"','"+std_age+"','"+std_sdep+"','"+std_spe
117、c+"','"+std_class+"')";</p><p> if(!oraclesql.executeUpdate(sql)){</p><p> JOptionPane.showMessageDialog(this,"未查詢到結(jié)果","",</p>&l
118、t;p> JOptionPane.ERROR_MESSAGE);</p><p><b> return;</b></p><p><b> }</b></p><p><b> else{</b></p><p> JOptionPane.showMes
119、sageDialog(this,"插入成功");</p><p> return;</p><p><b> }</b></p><p> 其中sql語(yǔ)句中的('"+std_id+"','"+std_name+"','"
120、+std_sex+"','"+std_age+"','"+std_sdep+"','"+std_spec+"','"+std_class+"'分別是輸入的值。</p><p> 分?jǐn)?shù)查詢頁(yè)面設(shè)計(jì)如下:</p><p> 查詢按
121、鈕監(jiān)聽(tīng)器函數(shù)主要代碼如下</p><p> if(stu_term.equals(""))</p><p><b> {</b></p><p> sql = "select student.sno,student.sname,cname,grade " +</p><p>
122、 "from turing.student,turing.course,turing.sc " +</p><p> "where student.sno=sc.sno and course.cno = sc.cno and student.sno like '"+stu_id+"'%";</p><p>
123、// sql="select sno,cno,grade,term from turing.sc where sno='"+stu_id+"'";</p><p><b> }</b></p><p><b> else</b></p><p> sql =
124、"select student.sno,student.sname,cname,grade " +</p><p> "from turing.student,turing.course,turing.sc " +</p><p> "where student.sno=sc.sno and course.cno = sc.cno an
125、d sc.term like '"+stu_term+"'% and student.sno like '"+stu_id+"'%";</p><p><b> try {</b></p><p> if(!oraclesql.executeQuery(sql)){</p>
126、;<p> JOptionPane.showMessageDialog(this,"未查詢到結(jié)果","",</p><p> JOptionPane.ERROR_MESSAGE);</p><p><b> return;</b></p><p><b> }</b&
127、gt;</p><p> } catch (HeadlessException | SQLException e1) {</p><p> // TODO Auto-generated catch block</p><p> e1.printStackTrace();</p><p><b> }</b><
128、;/p><p> v_data=oraclesql.Rows;</p><p> //v_head=oraclesql.columnHeads;</p><p><b> //更新表格模型</b></p><p> DefaultTableModel dtm=new DefaultTableModel(v_data,
129、v_head);</p><p> jt.setModel(dtm);</p><p> //更新顯示((DefaultTableModel)jt.getModel()).fireTableStructureChanged();</p><p><b> }</b></p><p> 其中學(xué)號(hào)必須輸入,
130、學(xué)期可以為空,當(dāng)學(xué)期為空時(shí)查詢?cè)搶W(xué)號(hào)下的所有成績(jī)。</p><p><b> 成績(jī)更新頁(yè)面設(shè)計(jì):</b></p><p><b> 頁(yè)面效果圖:</b></p><p> 其中查詢按鈕和之前的查詢頁(yè)面設(shè)計(jì)一樣,</p><p><b> 添加按鈕函數(shù):</b></
131、p><p> 單擊一次,信息一欄四個(gè)編輯框中的值設(shè)置為空,在編輯框中設(shè)置相應(yīng)的值后再次單擊執(zhí)行添加操作,代碼如下</p><p> if(i%2==0){</p><p> jtfArray[2].setText("");</p><p> jtfArray[3].setText("");</
132、p><p> jtfArray[4].setText("");</p><p> jtfArray[5].setText("");</p><p><b> i++;</b></p><p> jb3.setText("確認(rèn)");</p>&l
133、t;p><b> }</b></p><p><b> else{</b></p><p> String sno=jtfArray[2].getText().trim();</p><p> String cno=jtfArray[3].getText().trim();</p><p&
134、gt; String grad=jtfArray[4].getText().trim();</p><p> String term=jtfArray[5].getText().trim();</p><p> Integer grade = Integer.valueOf(grad);</p><p> OracleSQL oracle2= new Ora
135、cleSQL();</p><p> sql="insert into turing.sc values('"+sno+"','"+cno+"','"+grade+"','"+term+"')";</p><p> if(o
136、racle2.executeUpdate(sql)){</p><p> jb3.setText("添加");</p><p><b> i++;</b></p><p> JOptionPane.showMessageDialog(this,"添加成功","",</p&g
137、t;<p> JOptionPane.ERROR_MESSAGE);</p><p><b> return;</b></p><p><b> }</b></p><p><b> else{</b></p><p> jb3.setText(&qu
138、ot;添加");</p><p><b> i++;</b></p><p> JOptionPane.showMessageDialog(this,"添加失敗");</p><p> return;</p><p><b> }</b></p&
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)---學(xué)生成績(jī)管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)(學(xué)生成績(jī)管理系統(tǒng))
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)---學(xué)生成績(jī)管理系統(tǒng)數(shù)據(jù)庫(kù)設(shè)計(jì)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng)
- 學(xué)生成績(jī)管理系統(tǒng)-數(shù)據(jù)庫(kù)課程設(shè)計(jì)
- 學(xué)生成績(jī)管理系統(tǒng)數(shù)據(jù)庫(kù)課程設(shè)計(jì)
- 數(shù)據(jù)庫(kù)學(xué)生成績(jī)管理系統(tǒng)課程設(shè)計(jì)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)——學(xué)生成績(jī)管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)----學(xué)生成績(jī)管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)--- 學(xué)生成績(jī)管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)----學(xué)生成績(jī)管理系統(tǒng)
- 學(xué)生成績(jī)管理系統(tǒng)-數(shù)據(jù)庫(kù)課程設(shè)計(jì)
- 學(xué)生成績(jī)管理系統(tǒng)-數(shù)據(jù)庫(kù)課程設(shè)計(jì)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)----學(xué)生成績(jī)管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)---學(xué)生成績(jī)管理系統(tǒng)設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論