高考信息管理系統(tǒng)--java課程設(shè)計(jì)_第1頁
已閱讀1頁,還剩20頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p>  JAVA程序設(shè)計(jì) 課程設(shè)計(jì)報(bào)告</p><p>  課 題: </p><p>  姓 名: </p><p>  學(xué) 號(hào): </p><p>  同組姓名:

2、 </p><p>  專業(yè)班級(jí): </p><p>  指導(dǎo)教師: </p><p>  設(shè)計(jì)時(shí)間:2011-2-22 </p><p>  目 錄</p><p

3、>  一、課程設(shè)計(jì)目的和意義2</p><p>  二、高考信息管理系統(tǒng)數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)3</p><p>  三、主控界面的設(shè)計(jì)5</p><p><b>  四、系統(tǒng)設(shè)計(jì)10</b></p><p>  五、數(shù)據(jù)源連接說明14</p><p>  六、運(yùn)行截圖及說明16<

4、/p><p><b>  七、小結(jié)19</b></p><p><b>  八、參考文獻(xiàn)20</b></p><p>  一、課程設(shè)計(jì)目的和意義</p><p>  高考成績(jī)的統(tǒng)計(jì)和查詢工作是非常重要的,高考成績(jī)面向的是全國(guó)范圍內(nèi)的考生,它涉及的面比較廣、數(shù)據(jù)量大,如果在設(shè)計(jì)上出現(xiàn)什么問題,都會(huì)在社

5、會(huì)上產(chǎn)生巨大的影響。在這里我們只是簡(jiǎn)單地做一個(gè)高考成績(jī)查詢和統(tǒng)計(jì)的小系統(tǒng),并沒有考慮安全性等方面的的問題,主要目的是通過這個(gè)課程設(shè)計(jì)的學(xué)習(xí),對(duì)用JAVA開發(fā)數(shù)據(jù)庫系統(tǒng)有更為深刻的認(rèn)識(shí)。還有本次我們開發(fā)的是高考管理系統(tǒng)是以“3+2”為模型的。</p><p>  高考成績(jī)管理模塊主要實(shí)現(xiàn)以下功能:</p><p> ?。?)高考成績(jī)錄入。高考成績(jī)錄入包括成績(jī)的添加、修改、編輯和自動(dòng)統(tǒng)計(jì)等功能

6、。目前高考主要包括兩個(gè)方面:文科和理科。文科成績(jī)錄入和理科成績(jī)錄入分別是兩個(gè)不同的模塊。</p><p> ?。?)高考成績(jī)查詢。成績(jī)查詢也分為理科查詢和文科查詢兩個(gè)部分,成績(jī)查詢部分最好是應(yīng)用準(zhǔn)考證查詢,這是因?yàn)闇?zhǔn)考證號(hào)是全國(guó)統(tǒng)一并且唯一的,這樣就避免了同名同姓出現(xiàn)查詢重復(fù)的。如圖1所示,在這個(gè)系統(tǒng)中,包含4個(gè)模塊:理科成績(jī)錄入、理科成績(jī)查詢、文科成績(jī)錄入和文科成績(jī)查詢。其中,理科成績(jī)錄入和文科成績(jī)錄入、理科成

7、績(jī)查詢和文科成績(jī)查詢兩個(gè)模塊的設(shè)計(jì)思想基本一致。</p><p> ?。?)建立理(文)科成績(jī)錄入和查詢界面。建立一個(gè)理科數(shù)據(jù)庫表,用來記錄準(zhǔn)考證號(hào)(這個(gè)作為數(shù)據(jù)庫表的主鍵,惟一標(biāo)識(shí))、學(xué)生考號(hào)和姓名。另外再建立一個(gè)理科數(shù)據(jù)庫表,用來記錄學(xué)生姓名、考號(hào)之外的其他信息,并記錄各科的成績(jī)。</p><p>  (4)本系統(tǒng)查詢與成績(jī)?cè)O(shè)計(jì)。系統(tǒng)設(shè)計(jì)要求在考生查詢的同時(shí)自動(dòng)進(jìn)行統(tǒng)計(jì)工作,這是一種人

8、性化的需求,統(tǒng)計(jì)和查詢只需要一個(gè)事件代碼和一個(gè)執(zhí)行動(dòng)作即可完成。</p><p>  高考系統(tǒng)模塊設(shè)計(jì)如下圖1所示:</p><p>  圖1 高考系統(tǒng)模塊設(shè)計(jì)</p><p>  二、高考信息管理系統(tǒng)數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)</p><p>  文科數(shù)據(jù)表的設(shè)計(jì)與理科表的設(shè)計(jì)方式基本上一致,并且本人負(fù)責(zé)的是理科查詢部分,在這里就不詳細(xì)介紹文科的了,

9、下面介紹理科表詳細(xì)設(shè)計(jì)。</p><p><b>  1、理科主數(shù)據(jù)表</b></p><p>  建立理科主數(shù)據(jù)表,如表1所示。</p><p>  表1 理科主數(shù)據(jù)表的結(jié)構(gòu)</p><p>  數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)如圖2所示,該結(jié)構(gòu)說明在數(shù)據(jù)表的結(jié)構(gòu)創(chuàng)建時(shí),設(shè)置了準(zhǔn)考證號(hào)為關(guān)鍵字段,即在cardID的左邊有一個(gè)鑰匙的

10、符號(hào),是關(guān)鍵字的符號(hào)。另個(gè)添加了學(xué)生姓名,還設(shè)計(jì)了該考生的考前學(xué)校,這樣,當(dāng)查詢到該考號(hào)時(shí)就可以知道該生所在學(xué)校。</p><p><b>  2、理科從數(shù)據(jù)表</b></p><p>  從表的字段主要包括4個(gè)字段,即科目序號(hào)、考試成績(jī)、準(zhǔn)考證號(hào)和考試科目,如下表2所示。</p><p>  表2 理科從數(shù)據(jù)表</p>&l

11、t;p>  理科從數(shù)據(jù)表設(shè)計(jì)如圖3所示,該結(jié)構(gòu)說明在數(shù)據(jù)表的結(jié)構(gòu)創(chuàng)建時(shí),設(shè)置了準(zhǔn)考證號(hào)和科目序號(hào)一起作為關(guān)鍵字段,即在cardID和subjectID的左邊有一個(gè)鑰匙的符號(hào),是關(guān)鍵字的符號(hào)。另個(gè)添加了考試科目、考試成績(jī)和與考試科目對(duì)應(yīng)的字段。</p><p>  圖2 理科主數(shù)據(jù)表</p><p>  圖3 理科從數(shù)據(jù)表</p><p><b>

12、  三、主控界面的設(shè)計(jì)</b></p><p>  主控界面主要用來調(diào)用其他界面,這個(gè)界面的主要作用是顯示理科成績(jī)錄入、理科成績(jī)查詢、文科成績(jī)錄入和文科成績(jī)查詢4個(gè)界面,可以根據(jù)需要對(duì)其進(jìn)行選擇。它的基本結(jié)構(gòu)如圖4所示。</p><p><b>  圖4 主控界面圖</b></p><p>  1、主控界面放入控件與窗體布局:<

13、;/p><p>  (1)在控件中放入一個(gè)jPanel,將布局方式改為xyLayout.</p><p>  (2)在控件中放入4個(gè)jLabel:jLabel1、jLabel2、jLabel3、jLabel4,主要是用來設(shè)計(jì)整個(gè)界面的布局。</p><p> ?。?)在控件中放入4個(gè)jRadioButton:rdbInputScnAch(理科成績(jī)錄入)、rdbQuer

14、yScnAch(理科成績(jī)查詢)、rdbInputArtAch(文科成績(jī)錄入)、rdbQueryArtAch(文科成績(jī)查詢)。</p><p> ?。?)添加鼠標(biāo)單擊事件rdbInputScnAch_mouseClickd(MouseEvent e)、rdbQueryScnAch_mouseClickd(MouseEvent e)、rdbInputArtAch_mouseClickd(MouseEvent e)、r

15、dbQuerytArtAch_mouseClickd(MouseEvent e).</p><p>  2、主控界面設(shè)計(jì)具體代碼如下所示:</p><p>  package infomanagement;</p><p>  import java.awt.*;</p><p>  import java.awt.event.*;</

16、p><p>  import javax.swing.*;</p><p>  import com.borland.jbcl.layout.*;</p><p>  import javax.swing.border.*;</p><p>  public class Frame1 extends JFrame {</p><

17、;p>  private JPanel contentPane;</p><p>  private BorderLayout borderLayout1 = new BorderLayout();</p><p>  private JPanel jPanel1 = new JPanel();</p><p>  //設(shè)置jPanel1的布局方式為xylay

18、out,任意布局</p><p>  private XYLayout xYLayout1 = new XYLayout();</p><p>  private JLabel jLabel1 = new JLabel();</p><p>  private TitledBorder titledBorder1;</p><p>  pri

19、vate JLabel jLabel2 = new JLabel();</p><p>  private JLabel jLabel3 = new JLabel();</p><p>  private JLabel jLabel4 = new JLabel();</p><p><b>  //理科成績(jī)錄入</b></p>&

20、lt;p>  private JRadioButton rdbInputScnAch = new JRadioButton();</p><p><b>  //理科成績(jī)查詢</b></p><p>  private JRadioButton rdbQqueryScnAch = new JRadioButton();</p><p>&

21、lt;b>  //文科成績(jī)錄入</b></p><p>  private JRadioButton rdbInputArtAch = new JRadioButton();</p><p><b>  //文科成績(jī)查詢</b></p><p>  private JRadioButton rdbQueryArtAch = n

22、ew JRadioButton();</p><p><b>  //建立框架</b></p><p>  public Frame1() {</p><p>  enableEvents(AWTEvent.WINDOW_EVENT_MASK);</p><p><b>  try {</b><

23、;/p><p><b>  jbInit();</b></p><p><b>  }</b></p><p>  catch(Exception e) {</p><p>  e.printStackTrace();</p><p><b>  }</b>

24、</p><p><b>  }</b></p><p><b>  //組件初始化</b></p><p>  private void jbInit() throws Exception {</p><p>  contentPane = (JPanel) this.getContentPan

25、e();</p><p>  titledBorder1 = new TitledBorder("");</p><p>  contentPane.setLayout(borderLayout1);</p><p>  this.setSize(new Dimension(399, 288));</p><p>  th

26、is.setTitle("Frame Title");</p><p>  jPanel1.setLayout(xYLayout1);</p><p>  jLabel1.setFont(new java.awt.Font("Dialog", 0, 23));</p><p>  jLabel1.setForeground(C

27、olor.green);</p><p>  jLabel1.setBorder(titledBorder1);</p><p><b>  //輸入項(xiàng)目標(biāo)題</b></p><p>  jLabel1.setText(" 通用高考成績(jī)管理系統(tǒng)");</p><p>  //

28、設(shè)置jLabel2的邊界為etch</p><p>  jLabel2.setBorder(BorderFactory.createEtchedBorder());</p><p>  jLabel3.setText("請(qǐng)選擇");</p><p>  jLabel4.setBorder(BorderFactory.createEtchedBor

29、der());</p><p>  jLabel4.setToolTipText("");</p><p>  //將文字顏色設(shè)為紅色</p><p>  rdbInputScnAch.setForeground(Color.red);</p><p>  //rdbInputScnAch的標(biāo)題 理科成績(jī)錄入</p&

30、gt;<p>  rdbInputScnAch.setText("理科成績(jī)錄入");</p><p>  //加入jRadioButton事件,rdbInputScnAch(理科成績(jī)錄入)</p><p>  rdbInputScnAch.addMouseListener(new java.awt.event.MouseAdapter() {</p&

31、gt;<p>  //添加鼠標(biāo)單擊事件</p><p>  public void mouseClicked(MouseEvent e) {</p><p>  rdbInputScnAch_mouseClicked(e);</p><p><b>  }</b></p><p><b>  })

32、;</b></p><p>  //將文字顏色設(shè)為紅色</p><p>  rdbQqueryScnAch.setForeground(Color.red);</p><p>  //rdbQqueryScnAch的標(biāo)題 理科成績(jī)查詢</p><p>  rdbQqueryScnAch.setText("理科成績(jī)查詢&q

33、uot;);</p><p>  //加入jRadioButton事件 rdbQqueryScnAch("理科成績(jī)查詢")</p><p>  rdbQqueryScnAch.addMouseListener(new java.awt.event.MouseAdapter() {</p><p>  //添加鼠標(biāo)單擊事件</p>&

34、lt;p>  public void mouseClicked(MouseEvent e) {</p><p>  rdbQqueryScnAch_mouseClicked(e);</p><p><b>  }</b></p><p><b>  });</b></p><p>  //將文

35、字顏色設(shè)為紅色</p><p>  rdbInputArtAch.setForeground(Color.red);</p><p>  //rdbInputArtAch的標(biāo)題 文科成績(jī)錄入</p><p>  rdbInputArtAch.setText("文科成績(jī)錄入");</p><p>  //加入jRadioBu

36、tton事件 rdbInputArtAch("文科成績(jī)錄入")</p><p>  rdbInputArtAch.addMouseListener(new java.awt.event.MouseAdapter() {</p><p>  //添加鼠標(biāo)單擊事件</p><p>  public void mouseClicked(MouseEve

37、nt e) {</p><p>  rdbInputArtAch_mouseClicked(e);</p><p><b>  }</b></p><p><b>  });</b></p><p>  //將文字顏色設(shè)為紅色</p><p>  rdbQueryArtAch

38、.setForeground(Color.red);</p><p>  //rdbQueryArtAch的標(biāo)題 文科成績(jī)查詢</p><p>  rdbQueryArtAch.setText("文科成績(jī)查詢");</p><p>  //加入jRadioButton事件 rdbQueryArtAch("文科成績(jī)查詢")<

39、;/p><p>  rdbQueryArtAch.addMouseListener(new java.awt.event.MouseAdapter() {</p><p>  //添加鼠標(biāo)單擊事件</p><p>  public void mouseClicked(MouseEvent e) {</p><p>  rdbQueryArtAch

40、_mouseClicked(e);</p><p><b>  }</b></p><p><b>  });</b></p><p>  contentPane.add(jPanel1, BorderLayout.CENTER);</p><p>  //放置jLanel1在jPanel1中的位置

41、</p><p>  jPanel1.add(jLabel1, new XYConstraints(0, 0, 400, 47));</p><p>  //放置jLanel2在jPanel1中的位置</p><p>  jPanel1.add(jLabel2, new XYConstraints(1, 46, 398, 242));</p>

42、<p>  //放置rdbInputScnAch在jPanel1中的位置</p><p>  jPanel1.add(rdbInputScnAch, new XYConstraints(50, 130, -1, -1));</p><p>  //放置rdbQqueryScnAch在jPanel1中的位置</p><p>  jPanel1.add(r

43、dbQqueryScnAch, new XYConstraints(200, 130, -1, -1));</p><p>  //放置rdbInputArtAch在jPanel1中的位置</p><p>  jPanel1.add(rdbInputArtAch, new XYConstraints(50, 200, -1, -1));</p><p>  

44、//放置rdbQueryArtAch在jPanel1中的位置</p><p>  jPanel1.add(rdbQueryArtAch, new XYConstraints(200, 200, -1, -1));</p><p>  //放置jLanel3在jPanel1中的位置</p><p>  jPanel1.add(jLabel3, new XYCon

45、straints(3, 48, 92, 22));</p><p>  //放置jLanel4在jPanel1中的位置</p><p>  jPanel1.add(jLabel4, new XYConstraints(33, 94, 320, 165));</p><p><b>  }</b></p><p>  //

46、當(dāng)窗口關(guān)閉時(shí),退出系統(tǒng)</p><p>  protected void processWindowEvent(WindowEvent e) {</p><p>  super.processWindowEvent(e);</p><p>  if (e.getID() == WindowEvent.WINDOW_CLOSING) {</p><

47、p>  System.exit(0);</p><p><b>  }</b></p><p><b>  }</b></p><p>  //顯示理科成績(jī)錄入界面</p><p>  void rdbInputScnAch_mouseClicked(MouseEvent e) {</p

48、><p>  //調(diào)用理科成績(jī)錄入界面對(duì)話框</p><p>  ScienceAchievement dlg = new ScienceAchievement();</p><p>  Dimension dlgSize = dlg.getPreferredSize();</p><p>  Dimension frmSize = getSiz

49、e();</p><p>  Point loc = getLocation();</p><p>  dlg.setLocation((frmSize.width - dlgSize.width) / 2 + loc.x, (frmSize.height - dlgSize.height) / 2 + loc.y);</p><p>  dlg.setModal(

50、true);</p><p>  dlg.pack();</p><p>  dlg.show();</p><p><b>  }</b></p><p>  //顯示理科成績(jī)查詢界面</p><p>  void rdbQqueryScnAch_mouseClicked(MouseEvent

51、e) {</p><p>  //調(diào)用理科成績(jī)查詢界面對(duì)話框</p><p>  ScienceQuery dlg = new ScienceQuery();</p><p>  Dimension dlgSize = dlg.getPreferredSize();</p><p>  Dimension frmSize = getSize(

52、);</p><p>  Point loc = getLocation();</p><p>  dlg.setLocation((frmSize.width - dlgSize.width) / 2 + loc.x, (frmSize.height - dlgSize.height) / 2 + loc.y);</p><p>  dlg.setModal(tr

53、ue);</p><p>  dlg.pack();</p><p>  dlg.show();</p><p><b>  }</b></p><p>  //顯示文科成績(jī)錄入界面</p><p>  void rdbInputArtAch_mouseClicked(MouseEvent e)

54、{</p><p>  //調(diào)用文科成績(jī)錄入界面對(duì)話框</p><p>  ArtsAchievement dlg = new ArtsAchievement();</p><p>  Dimension dlgSize = dlg.getPreferredSize();</p><p>  Dimension frmSize = getSi

55、ze();</p><p>  Point loc = getLocation();</p><p>  dlg.setLocation((frmSize.width - dlgSize.width) / 2 + loc.x, (frmSize.height - dlgSize.height) / 2 + loc.y);</p><p>  dlg.setModal

56、(true);</p><p>  dlg.pack();</p><p>  dlg.show();</p><p><b>  }</b></p><p>  //顯示文科成績(jī)查詢界面</p><p>  void rdbQueryArtAch_mouseClicked(MouseEvent

57、e) {</p><p>  //調(diào)用文科成績(jī)查詢界面對(duì)話框</p><p>  ArtsQuery dlg = new ArtsQuery();</p><p>  Dimension dlgSize = dlg.getPreferredSize();</p><p>  Dimension frmSize = getSize();<

58、/p><p>  Point loc = getLocation();</p><p>  dlg.setLocation((frmSize.width - dlgSize.width) / 2 + loc.x, (frmSize.height - dlgSize.height) / 2 + loc.y);</p><p>  dlg.setModal(true);&l

59、t;/p><p>  dlg.pack();</p><p>  dlg.show();</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  四、系統(tǒng)設(shè)計(jì)</b></p><p>

60、;  據(jù)分工不同,此處只說明本人負(fù)責(zé)的理科成績(jī)查詢?cè)O(shè)計(jì),文科成績(jī)錄入及查詢等其他功能部分由同組其他成員詳敘。</p><p>  1、理科成績(jī)查詢模塊窗體屬性事件的設(shè)計(jì)如下:</p><p>  (1)加入jPanel1,并設(shè)布局方式威爾xyLayout1。</p><p> ?。?)加入兩個(gè)jLabel,對(duì)窗體進(jìn)行整體布局。jLabel1的文本標(biāo)題設(shè)置為“理科成績(jī)

61、查詢”;jLabel2在整體布局時(shí)只是起到裝飾作用。</p><p>  (3)加入一個(gè)jLabel3,文本標(biāo)題為“準(zhǔn)考證號(hào)”。</p><p> ?。?)加入一個(gè)jTextField,將其命名為jtfCardID.</p><p> ?。?)加入一個(gè)jButton,將其命名為jbnQuery,文本設(shè)置為“執(zhí)行查詢”。</p><p> ?。?/p>

62、6)加入一個(gè)jLabel4,文本標(biāo)題設(shè)置為“總成績(jī)”。</p><p> ?。?)加入一個(gè)jdbTextField1。</p><p> ?。?)加入一個(gè)jButton,將其命名為jbnExit。</p><p> ?。?)加入一個(gè)數(shù)據(jù)庫控件database1,用于連接數(shù)據(jù)庫。</p><p>  (10)加入一個(gè)數(shù)據(jù)庫控件queryData

63、Set1,用于執(zhí)行SQL語句。</p><p> ?。?1)加入一個(gè)jdbTable1數(shù)據(jù)庫控件。 </p><p>  窗體屬性設(shè)計(jì)部分具體代碼如下:</p><p>  package infomanagement;</p><p>  import java.awt.*;</p><p>  import jav

64、ax.swing.*;</p><p>  import com.borland.jbcl.layout.*;</p><p>  import com.borland.dbswing.*;</p><p>  import com.borland.dx.sql.dataset.*;</p><p>  import java.awt.eve

65、nt.*;</p><p>  import com.borland.dx.dataset.*;</p><p>  public class ScienceQuery extends JDialog {</p><p>  private JPanel jPanel1 = new JPanel(); //添加新的面板</p><p> 

66、 private XYLayout xYLayout1 = new XYLayout();</p><p>  private JLabel jLabel1 = new JLabel(); //添加“理科成績(jī)查詢標(biāo)簽”</p><p>  private JLabel jLabel2 = new JLabel(); //添加一個(gè)標(biāo)簽,完成界面布局</p><p&

67、gt;  private JLabel jLabel3 = new JLabel(); //添加“準(zhǔn)考證號(hào)”標(biāo)簽</p><p>  private JTextField jtfCardID = new JTextField();</p><p>  private JButton jbnQuery = new JButton();</p><p>  priv

68、ate Database database1 = new Database();</p><p>  private QueryDataSet queryDataSet1 = new QueryDataSet(); //添加數(shù)據(jù)集queryDataSet1</p><p>  private JdbTable jdbTable1 = new JdbTable();</p>&

69、lt;p>  private JLabel jLabel4 = new JLabel(); //添加“總成績(jī)”標(biāo)簽</p><p>  private JLabel jLabel5 = new JLabel(); //添加“退出”標(biāo)簽</p><p>  private JButton jbnExit = new JButton();</p><p

70、>  private Column column1 = new Column();</p><p>  private Column column2 = new Column();</p><p>  private Column column3 = new Column();</p><p>  private Column column4 = new Co

71、lumn();</p><p>  private Column column5 = new Column();</p><p>  private JdbTextField jdbTextField1 = new JdbTextField();</p><p>  private QueryDataSet queryDataSet2 = new QueryData

72、Set();</p><p>  public ScienceQuery(Frame frame, String title, boolean modal) {</p><p>  super(frame, title, modal);</p><p><b>  try {</b></p><p><b> 

73、 jbInit();</b></p><p><b>  pack();</b></p><p><b>  }</b></p><p>  catch(Exception ex) {</p><p>  ex.printStackTrace();</p><p>

74、;<b>  }</b></p><p><b>  }</b></p><p>  public ScienceQuery() {</p><p>  this(null, "", false);</p><p><b>  }</b></p>

75、<p>  private void jbInit() throws Exception {</p><p>  //設(shè)置jPanel1為任意放置</p><p>  jPanel1.setLayout(xYLayout1);</p><p>  jLabel1.setFont(new java.awt.Font("Dialog",

76、 0, 23));</p><p>  jLabel1.setForeground(Color.magenta);</p><p>  jLabel1.setBorder(BorderFactory.createEtchedBorder());</p><p>  //設(shè)置文本標(biāo)題 理科成績(jī)查詢</p><p>  jLabel1.setTe

77、xt("理科成績(jī)查詢");</p><p>  jLabel2.setBorder(BorderFactory.createEtchedBorder());</p><p>  //設(shè)置文本標(biāo)題 準(zhǔn)考證號(hào)</p><p>  jLabel3.setText("準(zhǔn)考證號(hào)");</p><p><b&

78、gt;  //設(shè)置文本標(biāo)題</b></p><p>  jbnQuery.setText("執(zhí)行查詢");</p><p>  jbnQuery.addActionListener(new java.awt.event.ActionListener() {</p><p>  public void actionPerformed(A

79、ctionEvent e) {</p><p>  jbnQuery_actionPerformed(e);</p><p><b>  }</b></p><p><b>  });</b></p><p>  //連接數(shù)據(jù)庫(local)</p><p>  databa

80、se1.setConnection(new com.borland.dx.sql.dataset.ConnectionDescriptor("jdbc:odbc:local","sa","",false, "sun.jdbc.odbc.JdbcOdbcDriver"));</p><p>  //設(shè)置文本標(biāo)題 執(zhí)行查詢</p&g

81、t;<p>  jLabel4.setText("總成績(jī)");</p><p>  //設(shè)置文本標(biāo)題 退出</p><p>  jbnExit.setText("退出");</p><p><b>  //添加退出事件</b></p><p>  jbnExit.ad

82、dActionListener(new java.awt.event.ActionListener() {</p><p>  public void actionPerformed(ActionEvent e) {</p><p>  jbnExit_actionPerformed(e);</p><p><b>  }</b></p&

83、gt;<p><b>  });</b></p><p>  column1.setColumnName("NewColumn1");</p><p>  column1.setDataType(com.borland.dx.dataset.Variant.STRING);</p><p>  column1.

84、setPreferredOrdinal(4);</p><p>  column1.setServerColumnName("NewColumn1");</p><p>  column1.setSqlType(0);</p><p>  column2.setColumnName("subject");</p>

85、<p>  column2.setDataType(com.borland.dx.dataset.Variant.STRING);</p><p>  column2.setPrecision(50);</p><p>  column2.setPreferredOrdinal(0);</p><p>  column2.setSchemaName(&q

86、uot;dbo");</p><p>  column2.setTableName("science2");</p><p>  column2.setServerColumnName("subject");</p><p>  column2.setSqlType(12);</p><p>

87、  column3.setColumnName("subjectNameID");</p><p>  column3.setDataType(com.borland.dx.dataset.Variant.LONG);</p><p>  column3.setPreferredOrdinal(1);</p><p>  column3.setS

88、chemaName("dbo");</p><p>  column3.setTableName("science2");</p><p>  column3.setServerColumnName("subjectNameID");</p><p>  column3.setSqlType(-5);<

89、;/p><p>  column4.setColumnName("cardID");</p><p>  column4.setDataType(com.borland.dx.dataset.Variant.LONG);</p><p>  column4.setPreferredOrdinal(2);</p><p>  c

90、olumn4.setSchemaName("dbo");</p><p>  column4.setTableName("science2");</p><p>  column4.setServerColumnName("cardID");</p><p>  column4.setSqlType(-5)

91、;</p><p>  column5.setColumnName("achievement");</p><p>  column5.setDataType(com.borland.dx.dataset.Variant.STRING);</p><p>  column5.setPrecision(50);</p><p&g

92、t;  column5.setPreferredOrdinal(3);</p><p>  column5.setSchemaName("dbo");</p><p>  column5.setTableName("science2");</p><p>  column5.setServerColumnName("

93、achievement");</p><p>  column5.setSqlType(12);</p><p>  this.getContentPane().add(jPanel1, BorderLayout.CENTER);</p><p>  //在jPanel1中放置各個(gè)控件</p><p>  jPanel1.add(j

94、Label1, new XYConstraints(0, 1, 399, 53));</p><p>  jPanel1.add(jLabel3, new XYConstraints(10, 66, 80, 19));</p><p>  jPanel1.add(jtfCardID, new XYConstraints(97, 66, 80, 21));</p>&

95、lt;p>  jPanel1.add(jLabel2, new XYConstraints(0, 53, 398, 49));</p><p>  jPanel1.add(jbnQuery, new XYConstraints(300, 66, 90, 22));</p><p>  jPanel1.add(jdbTable1, new XYConstrai

96、nts(0, 100, 398, 154));</p><p>  jPanel1.add(jLabel4, new XYConstraints(10, 268, 80, 20));</p><p>  jPanel1.add(jbnExit, new XYConstraints(300, 268, 90, 20));</p><p>  jPane

97、l1.add(jdbTextField1, new XYConstraints(100, 268, 90, 20));</p><p><b>  }</b></p><p><b>  //定義退出方法</b></p><p>  void cancel(){</p><p>  dispo

98、se() ;</p><p><b>  }</b></p><p><b>  //退出事件</b></p><p>  void jbnExit_actionPerformed(ActionEvent e) {</p><p>  cancel();}</p><p>&

99、lt;b>  }</b></p><p>  2、成績(jī)查詢流程圖如下:</p><p>  圖5 理科成績(jī)查詢流程圖</p><p><b>  五、數(shù)據(jù)源連接說明</b></p><p>  在SQL Server 里創(chuàng)建數(shù)據(jù)庫和表后,前臺(tái)界面設(shè)計(jì)好,就開始前后臺(tái)數(shù)據(jù)源的連接了。我們采用的是ODBC數(shù)

100、據(jù)源連接,具體做法是在電腦控制面板中點(diǎn)擊“管理工具”—>“數(shù)據(jù)源(ODBC)”,彈出數(shù)據(jù)源管理器對(duì)話框,選擇系統(tǒng)DNS面板,配置SQL sever DNS,如圖6所示,接著一步一步選擇相應(yīng)數(shù)據(jù)庫等簡(jiǎn)單步驟,最后測(cè)試數(shù)據(jù)源,確定即可,見圖7。</p><p><b>  圖 6 配置數(shù)據(jù)源</b></p><p><b>  圖7 測(cè)試數(shù)據(jù)源</b

101、></p><p><b>  六、運(yùn)行截圖及說明</b></p><p>  本人負(fù)責(zé)理科查詢,此處只貼出理科查詢運(yùn)行情況,其他功能部分運(yùn)行截圖略去。</p><p>  理科成績(jī)查詢?nèi)缦聢D15:</p><p>  圖15 理科成績(jī)查詢截圖</p><p>  上述查詢結(jié)果由輸入準(zhǔn)考證號(hào)

102、,點(diǎn)擊“執(zhí)行查詢”觸發(fā)數(shù)據(jù)集執(zhí)行數(shù)據(jù)庫里查詢,主要方法代碼如下:</p><p><b>  //執(zhí)行查詢語句</b></p><p>  void jbnQuery_actionPerformed(ActionEvent e) {</p><p><b>  //進(jìn)行數(shù)據(jù)查詢</b></p><p&g

103、t;<b>  try{</b></p><p>  queryDataSet1 = new QueryDataSet();</p><p>  queryDataSet2 = new QueryDataSet();</p><p><b>  //獲得準(zhǔn)考證號(hào)</b></p><p>  int

104、cardID1 = Integer.parseInt(jtfCardID.getText().trim());</p><p><b>  //查詢學(xué)習(xí)成績(jī)</b></p><p>  queryDataSet1.setQuery(new com.borland.dx.sql.dataset.QueryDescriptor(database1, "SELEC

105、T science2.cardID,science2.subject,science2.achievement,science2.subjectNameID " +</p><p>  "FROM info.dbo.science2 where science2.cardID = '"+cardID1+"'", null, true, Load.A

106、LL));</p><p>  //加入到j(luò)dbTable1中</p><p>  jdbTable1.setDataSet(queryDataSet1);</p><p>  //執(zhí)行sum語句,獲得成績(jī)總分</p><p>  queryDataSet2.setQuery(new com.borland.dx.sql.dataset.Qu

107、eryDescriptor(database1,"SELECT SUM(achievement) AS SUM_achievement FROM info.dbo.science2\n" +"where science2.cardID ='"+cardID1+"'", null, true, Load.ALL));</p><p>  /

108、/在jdbTextField1中加入一列</p><p>  jdbTextField1.setColumnName("SUM_achievement");</p><p>  //把數(shù)據(jù)集加入到j(luò)dbTextField1中</p><p>  jdbTextField1.setDataSet(queryDataSet2);</p>

109、<p><b>  }</b></p><p>  catch(Exception sql){</p><p>  JOptionPane.showMessageDialog(this,"準(zhǔn)考證不存在,請(qǐng)重試");</p><p>  sql.printStackTrace();</p><p

110、><b>  }</b></p><p><b>  }</b></p><p>  其中數(shù)據(jù)集QueryDataSet()在數(shù)據(jù)庫里的操作具體實(shí)現(xiàn)如下:</p><p>  package infomanagement;</p><p>  import com.borland.dx.dat

111、aset.*;</p><p>  public class QueryDataSet1RowIterator {</p><p>  private RowIterator rowIterator = new RowIterator();</p><p>  public QueryDataSet1RowIterator() {}</p><p

112、>  void bind(DataSet dataset) throws DataSetException {</p><p>  rowIterator.bind(dataset);</p><p><b>  }</b></p><p>  void bind(ReadRow readRow) throws DataSetExcept

113、ion {</p><p>  rowIterator.bind(readRow);</p><p><b>  }</b></p><p>  void bind(ReadWriteRow readWriteRow) throws DataSetException {</p><p>  rowIterator.bin

114、d(readWriteRow);</p><p><b>  }</b></p><p>  void bind(RowIterator ri) throws DataSetException {</p><p>  rowIterator.bind(ri);</p><p><b>  }</b>

115、</p><p><b>  //獲得第一條記錄</b></p><p>  public void first() throws DataSetException {</p><p>  rowIterator.first();</p><p><b>  }</b></p><

116、;p>  //獲得最后一條記錄</p><p>  public void last() throws DataSetException {</p><p>  rowIterator.last();</p><p><b>  }</b></p><p><b>  //獲得下一條記錄</b>

117、;</p><p>  public boolean next() throws DataSetException {</p><p>  return rowIterator.next();</p><p><b>  }</b></p><p><b>  //獲得上一條記錄</b></p

118、><p>  public boolean prior() throws DataSetException {</p><p>  return rowIterator.prior();</p><p><b>  }</b></p><p><b>  //獲得準(zhǔn)考證號(hào)</b></p>

119、<p>  public int getCardID() throws DataSetException { </p><p>  return rowIterator.getInt("cardID");</p><p><b>  }</b></p><p><b>  //設(shè)置準(zhǔn)考證號(hào)</b&

120、gt;</p><p>  public void setCardID(int value) throws DataSetException { </p><p>  rowIterator.setInt("cardID", value);</p><p><b>  }</b></p><p>&l

121、t;b>  //獲得學(xué)生姓名</b></p><p>  public String getStudentName() throws DataSetException { </p><p>  return rowIterator.getString("studentName");</p><p><b>  }&l

122、t;/b></p><p><b>  //設(shè)置學(xué)生姓名</b></p><p>  public void setStudentName(String value) throws DataSetException {</p><p>  rowIterator.setString("studentName", val

123、ue);</p><p><b>  } </b></p><p><b>  //獲得學(xué)校名</b></p><p>  public String getSchoolBefore() throws DataSetException { </p><p>  return rowIterator.

124、getString("schoolBefore");</p><p><b>  } </b></p><p><b>  //設(shè)置學(xué)校</b></p><p>  public void setSchoolBefore(String value) throws DataSetException {&l

125、t;/p><p>  rowIterator.setString("schoolBefore", value);</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  七、小結(jié)</b></p>

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論