圖書管理系統(tǒng)軟件工程課程設計_第1頁
已閱讀1頁,還剩41頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  《軟件工程—原理、方法與應用》</p><p><b>  課程設計報告書</b></p><p>  項目名稱:圖書管理系統(tǒng) </p><p>  指導老師: </p><p>  學生姓名:

2、 </p><p>  專 業(yè): </p><p>  學 號: </p><p>  日 期: </p><p

3、><b>  目錄</b></p><p><b>  一、項目計劃1</b></p><p><b> ?。ㄒ唬╉椖績?nèi)容1</b></p><p> ?。ǘ?開發(fā)環(huán)境1</p><p>  (三) 進度安排2</p><p>  二、結

4、構化分析設計2</p><p><b> ?。ㄒ唬?shù)據(jù)流圖2</b></p><p> ?。ǘ?數(shù)據(jù)字典3</p><p><b>  (三)加工說明6</b></p><p><b> ?。ㄋ模┙Y構圖6</b></p><p><b&

5、gt; ?。ㄎ澹?流程圖9</b></p><p>  三、面向?qū)ο蠓治鲈O計12</p><p><b> ?。ㄒ唬┯美龍D12</b></p><p> ?。ǘ?對象行為模型13</p><p> ?。ㄈ┫到y(tǒng)包圖14</p><p><b> ?。ㄋ模╊悎D14

6、</b></p><p><b>  四、系統(tǒng)實現(xiàn)16</b></p><p> ?。ㄒ唬┏绦虼a16</p><p> ?。ǘ┕δ苎菔?1</p><p><b>  五、測試34</b></p><p>  六、 軟件發(fā)布39</p>

7、<p><b>  七、總結體會40</b></p><p>  八、 參考文獻40</p><p><b>  一、項目計劃</b></p><p><b> ?。ㄒ唬╉椖績?nèi)容</b></p><p>  在計算機日漸走進普通家庭的今天,對于個人來講,采用一套

8、行之有效的圖書管理系統(tǒng)來管理自己的圖書是非常方便的;對圖書管理部門來講,以前單一的手工檢索已不能滿足人們的要求,伴隨著工業(yè)化、信息化的高速發(fā)展,圖書的數(shù)目越來越龐大,圖書種類也是越來越多樣化;因而往往是投入了大量的人力、物力和財力卻得不到高效的管理效率。為了便于圖書資料的管理、滿足人們的需求,不必浪費大量的時間耗費在圖書檢索上,這就需要有一個有效的圖書管理軟件來幫助人們管理,減輕工作人員的工作量,方便工作人員對它的操作,提高管理的質(zhì)量和

9、水平,做到高效、便捷和智能化管理,達到提高圖書管理效率的目的。基于這個問題,研發(fā)了這個圖書管理系統(tǒng)。</p><p>  該系統(tǒng)主要實現(xiàn)功能:管理員登錄及退出、讀者信息查詢、圖書的增加、刪除、更新和查詢。</p><p><b>  開發(fā)環(huán)境</b></p><p>  開發(fā)環(huán)境:Win 7 旗艦版。</p><p> 

10、 開發(fā)工具:SQL Server 2005 JCreator1.7 </p><p>  作圖軟件:Rational Rose Enterprise Edition 2003</p><p><b>  進度安排</b></p><p>  該軟件應用JCreater1.7和SQL Server 2005進行編程,歷時大概一周,最終完

11、成了這個小型圖書管理系統(tǒng)。由于時間倉促,該小型圖書管理系統(tǒng)并不完善。我用了兩天時間查找相關資料,兩天時間編寫代碼和連接數(shù)據(jù)庫。其余三天開始應用Rational Rose Enterprise Edition 2003畫數(shù)據(jù)流圖、結構圖、流程圖、用例圖和包圖類圖。整個過程系我一人完成。</p><p><b>  二、結構化分析設計</b></p><p><b&

12、gt; ?。ㄒ唬?shù)據(jù)流圖</b></p><p>  書籍信息 讀者信息</p><p>  讀者信息 查詢信息</p><p>  圖2.1-1圖書管理系統(tǒng)的頂層DFD</p><p><b>  book表</b></p>&l

13、t;p>  錄入信息 查詢請求</p><p>  更新信息 查詢結果</p><p><b>  reader表</b></p><p>  圖2.1-2圖書管理系統(tǒng)的第二層DFD</p><p>  book表

14、 reader表</p><p>  圖2.1-3圖書管理系統(tǒng)的第三層DFD</p><p><b>  查詢結果</b></p><p><b>  查詢請求</b></p><p>  無效請求 有效請求</p><p><

15、;b>  book表</b></p><p>  圖2.1-4圖書管理系統(tǒng)的第三層DFD</p><p><b>  數(shù)據(jù)字典</b></p><p><b>  數(shù)據(jù)流</b></p><p><b>  數(shù)據(jù)項</b></p><p&g

16、t;<b> ?。ㄈ┘庸ふf明</b></p><p>  審查用戶查詢書籍信息請求</p><p><b>  2.3圖-加工說明</b></p><p><b>  (四)結構圖</b></p><p>  圖2.4-1—圖書管理系統(tǒng)上層框架</p><

17、p>  圖2.4-2-圖書管理子系統(tǒng)初始SC圖</p><p>  圖2.4-3-圖書管理子系統(tǒng)初始SC圖</p><p>  圖2.4-4-圖書管理系統(tǒng)SC圖的上層框架</p><p><b>  流程圖</b></p><p>  圖2.5-1—圖書管理系統(tǒng)登錄流程圖</p><p> 

18、 圖2.5-2—讀者信息查詢流程圖</p><p>  圖2.5-3—添加書籍流程圖</p><p>  圖2.5-4—刪除書籍流程圖</p><p>  圖2.5-5—更新書籍流程圖</p><p>  圖2.5-6—查詢書籍流程圖</p><p>  三、面向?qū)ο蠓治鲈O計</p><p>&

19、lt;b> ?。ㄒ唬┯美龍D</b></p><p>  用例圖在需求分析階段有重要作用,它是作為參與者的外部用戶所能觀察到的系統(tǒng)功能模型圖。整個開發(fā)過程都是圍繞需求階段用例進行的。首先需要確定參與者。</p><p>  管理員在登錄后對讀者信息進行查詢以及對書籍的添加、刪除、更新和查詢。</p><p>  用戶在登錄后可以對書籍信息進行查詢。&

20、lt;/p><p>  圖書管理系統(tǒng)管理員-用戶用例圖</p><p><b>  對象行為模型</b></p><p>  繼續(xù)選擇服務 登錄錯誤</p><p><b>  登錄正確</b></p><p><b>  查詢讀者信

21、息</b></p><p><b> ?。ㄈ┫到y(tǒng)包圖</b></p><p>  數(shù)據(jù)庫包:包含數(shù)據(jù)庫中所有的數(shù)據(jù)信息</p><p>  用戶包:包含要使用系統(tǒng)的用戶及其屬性</p><p>  管理員包:包含要使用系統(tǒng)的管理員及其屬性</p><p>  接口包:表示系統(tǒng)和數(shù)據(jù)庫

22、的借口</p><p>  系統(tǒng)包:表示圖書管理系統(tǒng)</p><p><b>  (四)類圖</b></p><p>  類是面對對象系統(tǒng)組成的核心。類是對一組相同屬性、操作、關系和語義的對象的描述。這些對象包括了對現(xiàn)實世界中的物理實體、商業(yè)事務、邏輯事務、應用事務和行為事務等,甚至也包括了純粹概念性的事務,它們都是類的實例。</p>

23、;<p><b>  圖3.4-1類圖</b></p><p>  圖3.4-2系統(tǒng)的類圖</p><p><b>  四、系統(tǒng)實現(xiàn)</b></p><p><b>  (一)程序代碼</b></p><p><b>  1.主窗口界面</b>

24、;</p><p>  import java.awt.*;</p><p>  import java.awt.event.*;</p><p>  import javax.swing.*;</p><p>  import javax.swing.border.TitledBorder;</p><p>  im

25、port java.awt.Font;</p><p>  import javax.swing.JMenu;</p><p>  public class MainWindow extends JFrame implements ActionListener</p><p>  { private static final long serialVersion

26、UID = 1L;</p><p>  static String loginName;</p><p>  static String loginNo;</p><p>  JLabel mlabel;</p><p>  JPanel jp=new JPanel(); </p><p><b>

27、  //建立菜單欄</b></p><p>  JMenuBar menu=new JMenuBar();</p><p>  JMenu a=new JMenu();</p><p>  JMenu b=new JMenu();</p><p>  JMenu c=new JMenu();</p><p&g

28、t;  //建立系統(tǒng)管理菜單組</p><p>  JMenuItem aa=new JMenuItem();</p><p>  JMenuItem ab=new JMenuItem();</p><p>  JMenuItem ac=new JMenuItem();</p><p>  //建立讀者管理菜單組</p><

29、;p>  JMenuItem bb=new JMenuItem();</p><p>  //建立書籍管理菜單組</p><p>  JMenuItem ca=new JMenuItem();</p><p>  JMenuItem cb=new JMenuItem();</p><p>  JMenuItem cc=new JMenu

30、Item();</p><p>  JMenuItem cd=new JMenuItem();</p><p>  public MainWindow(){</p><p>  super("圖書管理系統(tǒng)");</p><p>  addWindowListener(new WindowAdapter(){</p&g

31、t;<p>  public void windowClosing(WindowEvent e){</p><p>  System.exit(0);}});</p><p>  Container d=getContentPane();</p><p>  this.setSize(300,200);</p><p>  th

32、is.setTitle("圖書管理系統(tǒng)");</p><p>  d.add(menu);</p><p>  menu.add(a);</p><p>  menu.add(b);</p><p>  menu.add(c);</p><p><b>  //添加菜單組</b>

33、;</p><p>  a.setText("系統(tǒng)管理");</p><p>  a.setFont(new Font("Dialog",0,12));</p><p>  b.setText("讀者管理");</p><p>  b.setFont(new Font("D

34、ialog",0,12));</p><p>  c.setText("書籍管理");</p><p>  c.setFont(new Font("Dialog",0,12));</p><p>  //生成系統(tǒng)管理菜單組的選項</p><p>  aa.setText("登錄&qu

35、ot;);</p><p>  aa.setFont(new Font("Dialog",0,12));</p><p>  ab.setText("退出登錄");</p><p>  ab.setFont(new Font("Dialog",0,12));</p><p>  ac

36、.setText("退出系統(tǒng)");</p><p>  ac.setFont(new Font("Dialog",0,12));</p><p>  //生成讀者管理菜單組的選項</p><p>  bb.setText("查詢讀者信息");</p><p>  bb.setFont

37、(new Font("Dialog",0,12));</p><p>  //生成書籍管理菜單組的選項</p><p>  ca.setText("添加書籍");</p><p>  ca.setFont(new Font("Dialog",0,12));</p><p>  cb.

38、setText("刪除書籍");</p><p>  cb.setFont(new Font("Dialog",0,12));</p><p>  cc.setText("查詢讀書信息");</p><p>  cc.setFont(new Font("Dialog",0,12));&l

39、t;/p><p>  cd.setText("更新書籍");</p><p>  cd.setFont(new Font("Dialog",0,12));</p><p>  //添加系統(tǒng)管理菜單組</p><p>  a.add(aa);</p><p>  a.add(ab);&

40、lt;/p><p>  a.add(ac);</p><p>  //添加讀者管理菜單組</p><p>  b.add(bb);</p><p>  //添加書籍管理菜單組</p><p>  c.add(ca);</p><p>  c.add(cb);</p><p>

41、  c.add(cc);</p><p>  c.add(cd);</p><p><b>  //添加事件偵聽</b></p><p>  aa.addActionListener(this);</p><p>  ab.addActionListener(this);</p><p>  ac

42、.addActionListener(this);</p><p>  bb.addActionListener(this);</p><p>  ca.addActionListener(this);</p><p>  cb.addActionListener(this);</p><p>  cc.addActionListener(t

43、his);</p><p>  cd.addActionListener(this);</p><p>  setJMenuBar(menu);}</p><p>  public void actionPerformed(ActionEvent e){</p><p>  if(e.getSource()==aa){</p>

44、<p>  UserLogin login=new UserLogin(this);</p><p>  login.setVisible(true);}</p><p>  if(e.getSource()==ab){</p><p>  setVisible(false);</p><p>  MainWindow mainFr

45、ame=new MainWindow();</p><p>  mainFrame.setLocation(400,150);</p><p>  mainFrame.setVisible(true);</p><p><b>  }</b></p><p>  if(e.getSource()==ac)</p&g

46、t;<p>  {System.exit(0);}</p><p>  if(e.getSource()==cc)</p><p>  {FindBook findbook=new FindBook();</p><p>  findbook.setVisible(true);</p><p><b>  }</

47、b></p><p>  if(e.getSource()==bb)</p><p><b>  {</b></p><p>  FindReader findreader=new FindReader();</p><p>  findreader.setVisible(true);</p><

48、;p><b>  }</b></p><p>  if(e.getSource()==ca)</p><p><b>  {</b></p><p>  AddBook addBook=new AddBook();</p><p>  addBook.setVisible(true);<

49、/p><p><b>  }</b></p><p>  if(e.getSource()==cb)</p><p><b>  {</b></p><p>  DeleteBook delBook=new DeleteBook();</p><p>  delBook.setV

50、isible(true);</p><p><b>  }</b></p><p>  if(e.getSource()==cd)</p><p><b>  {</b></p><p>  UpdateBook updBook=new UpdateBook();</p><p&

51、gt;  updBook.setVisible(true);</p><p><b>  }}</b></p><p>  public void setenabled(int right)</p><p>  {if(right==1)</p><p><b>  {</b></p>

52、<p>  b.setEnabled(true);</p><p>  c.setEnabled(true);}</p><p>  if(right==2)</p><p><b>  {</b></p><p>  b.setEnabled(true);</p><p>  c.s

53、etEnabled(true);}</p><p><b>  }</b></p><p>  public static void main (String[] args){</p><p>  MainWindow mainFrame=new MainWindow();</p><p>  mainFrame.set

54、Location(400,200);</p><p>  mainFrame.setVisible(true);</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  用戶登錄界面</b></p><p&

55、gt;  import java.awt.*;</p><p>  import java.awt.event.*;</p><p>  import javax.swing.*;</p><p>  import java.sql.*;</p><p>  import java.io.*;</p><p>  pu

56、blic class UserLogin extends JFrame implements ActionListener</p><p><b>  {</b></p><p>  private static final long serialVersionUID = 1L;</p><p>  String name;</p>

57、<p>  DataBaseManger db=new DataBaseManger();</p><p>  MainWindow mainFrame;</p><p>  JFrame f=null;</p><p>  JPanel panel1,panel2;</p><p>  JLabel UserLabel,Pas

58、swordLabel;</p><p>  JTextField UserTextField;</p><p>  JPasswordField PasswordTextField;</p><p>  JButton YesBtn,CancelBtn;</p><p>  Container c;</p><p> 

59、 ResultSet rs;</p><p>  public UserLogin(MainWindow mainFrame)</p><p><b>  {</b></p><p>  super("用戶登錄");</p><p>  this.mainFrame=mainFrame;</p&

60、gt;<p>  UserLabel=new JLabel("用戶名",JLabel.CENTER);</p><p>  PasswordLabel=new JLabel("密碼",JLabel.CENTER);</p><p>  UserTextField=new JTextField(10);</p><p&

61、gt;  PasswordTextField=new JPasswordField(10);</p><p>  YesBtn=new JButton("確定");</p><p>  CancelBtn=new JButton("取消");</p><p>  YesBtn.addActionListener(this);&

62、lt;/p><p>  CancelBtn.addActionListener(this);</p><p>  panel1=new JPanel();</p><p>  panel1.setLayout(new GridLayout(2,2));</p><p>  panel2=new JPanel();</p><p

63、>  c=getContentPane();</p><p>  c.setLayout(new BorderLayout());</p><p>  panel1.add(UserLabel);</p><p>  panel1.add(UserTextField);</p><p>  panel1.add(PasswordLabe

64、l);</p><p>  panel1.add(PasswordTextField);</p><p>  c.add(panel1,BorderLayout.CENTER);</p><p>  panel2.add(YesBtn);</p><p>  panel2.add(CancelBtn);</p><p>

65、;  c.add(panel2,BorderLayout.CENTER);</p><p>  setSize(300,150);</p><p>  JLabel JL=new JLabel();</p><p>  c.add(JL,"North");</p><p>  c.add(panel1,"Cent

66、er");</p><p>  c.add("South",panel2);</p><p>  panel1.setBackground(new Color(255,255,255));</p><p>  setLocation(400,200);</p><p><b>  }</b>

67、</p><p>  public void actionPerformed(ActionEvent e)</p><p>  {if(e.getSource()==CancelBtn)</p><p>  {this.dispose();}</p><p><b>  else</b></p><p

68、>  {char[] password=PasswordTextField.getPassword();</p><p>  String passwordSTR=new String(password);</p><p>  String strSQL;</p><p>  strSQL="select * from users where una

69、me='"+UserTextField.getText().trim()+"'and upassword='"+passwordSTR+"'";</p><p>  rs=db.getResult(strSQL);</p><p>  boolean isExist=false;</p><

70、;p><b>  try</b></p><p>  { rs.next();</p><p>  mainFrame.loginNo=rs.getString(1);</p><p>  name=rs.getString(1);</p><p>  mainFrame.loginName=name;<

71、/p><p>  int right;</p><p>  right=rs.getInt(1);</p><p>  mainFrame.setenabled(right);</p><p>  if(name.length()!=0)</p><p>  isExist=true;</p><p&g

72、t;<b>  }</b></p><p>  catch(Exception pe)</p><p>  { pe.printStackTrace(); }</p><p>  if(UserTextField.getText().trim().equals(""))</p><p><b&g

73、t;  {</b></p><p>  JOptionPane.showMessageDialog(null,"用戶名不可為空!");</p><p><b>  return;</b></p><p><b>  }</b></p><p>  if(passwor

74、dSTR.equals(""))</p><p><b>  {</b></p><p>  JOptionPane.showMessageDialog(null,"密碼不可為空!");</p><p><b>  return;</b></p><p>&l

75、t;b>  }</b></p><p>  if(!isExist)</p><p>  { JOptionPane.showMessageDialog(null,"用戶名不存在或者密碼不正確!");}</p><p><b>  else</b></p><p>  {JOptio

76、nPane.showMessageDialog(null,"登錄成功");</p><p>  this.dispose();}</p><p><b>  }}}</b></p><p><b>  讀者信息查詢</b></p><p>  import java.awt.*;

77、</p><p>  import java.awt.event.*;</p><p>  import javax.swing.*;</p><p>  import javax.swing.event.*;</p><p>  import java.sql.*;</p><p>  import java.lan

78、g.String;</p><p>  public class FindReader extends JFrame implements ActionListener</p><p>  { DataBaseManger db=new DataBaseManger();</p><p>  MainWindow mw=new MainWindow();<

79、/p><p>  ResultSet rs;</p><p>  JLabel select=new JLabel("請輸入證件號");</p><p>  JTextField jtf=new JTextField(10);</p><p>  JPanel p1=new JPanel();</p><p

80、>  JPanel p2=new JPanel();</p><p>  JPanel p3=new JPanel();</p><p>  JPanel p4=new JPanel(); </p><p>  JLabel lb=new JLabel("讀者信息");</p><p>  JButton findb

81、t=new JButton("查詢");</p><p>  JButton yesbt=new JButton("確定");</p><p>  JTextArea jta=new JTextArea(10,10);</p><p>  public FindReader()</p><p>  {

82、 super("查詢讀者信息");</p><p>  Container c=getContentPane();</p><p>  p1.add(select);</p><p>  p1.add(jtf);</p><p>  p1.add(findbt);</p><p>  c.add(

83、p1,BorderLayout.NORTH);</p><p>  p2.add(lb);p2.add(jta);</p><p>  c.add(p2,BorderLayout.CENTER);</p><p>  p4.add(yesbt);</p><p>  c.add(p4,BorderLayout.SOUTH);</p>

84、;<p>  yesbt.addActionListener(this);</p><p>  findbt.addActionListener(this);</p><p>  setSize(500,300);</p><p>  setVisible(true);</p><p>  setLocation(400,150

85、);</p><p><b>  }</b></p><p>  public void actionPerformed(ActionEvent e)</p><p><b>  {</b></p><p>  if(e.getActionCommand()=="確定")<

86、;/p><p>  this.dispose();</p><p>  if(e.getActionCommand()=="查詢")</p><p><b>  {</b></p><p>  String sno=jtf.getText();</p><p>  String s

87、qlstrR;</p><p>  if((mw.loginNo.trim().equals(sno))||(mw.loginName.trim().equals("admin")))</p><p>  { sqlstrR="select * from reader where sno='"+sno+"'";

88、</p><p>  rs=db.getResult(sqlstrR);</p><p><b>  try</b></p><p>  { rs.next();</p><p>  jta.setText("");</p><p>  jta.append("

89、學號為:"+rs.getString(1)+", "+"姓名為:"+rs.getString(2)+","+"性別為:"+rs.getString(3)+"\n");</p><p>  jta.append("年齡為:"+rs.getString(4)+", "

90、+"密碼為:"+rs.getString(5)+","+" 學院為:"+rs.getString(6)+"\n");</p><p>  String sqlstr="select * from lendbook where sno='"+sno+"'";</p>

91、<p>  rs=db.getResult(sqlstr);}</p><p>  catch(Exception pe) </p><p>  { pe.printStackTrace(); } }</p><p><b>  else</b></p><p><b>  {</b>

92、;</p><p>  JOptionPane.showMessageDialog(null,"請輸入正確的證件號!");</p><p><b>  }}}}</b></p><p><b>  增加圖書信息</b></p><p>  import java.awt.*;&l

93、t;/p><p>  import java.awt.event.*;</p><p>  import javax.swing.*;</p><p>  import javax.swing.event.*;</p><p>  import java.sql.*;</p><p>  public class AddB

94、ook extends JFrame implements ActionListener </p><p>  { MainWindow mw=new MainWindow();</p><p>  DataBaseManger db=new DataBaseManger();</p><p>  ResultSet rs;</p><p&g

95、t;  JPanel a,b,c,d,e,f;</p><p>  JLabel bname=new JLabel();</p><p>  JLabel bno=new JLabel();</p><p>  JLabel bnum=new JLabel();</p><p>  JLabel author=new JLabel();<

96、;/p><p>  JLabel publisher=new JLabel();</p><p>  JTextField tname=new JTextField(20);</p><p>  JTextField tno=new JTextField(20);</p><p>  JTextField tnum=new JTextField(

97、20);</p><p>  JTextField tauthor=new JTextField(20);</p><p>  JTextField tpublisher=new JTextField(20);</p><p>  JButton addbt=new JButton("添加");</p><p>  JBu

98、tton yesbt=new JButton("確定");</p><p>  JPanel p3=new JPanel();</p><p>  public AddBook()</p><p><b>  {</b></p><p>  super("添加圖書");</p

99、><p>  a=new JPanel();</p><p>  b=new JPanel();</p><p>  c=new JPanel();</p><p>  d=new JPanel();</p><p>  e=new JPanel();</p><p>  f=new JP

100、anel();</p><p>  bname.setText("書名 :");</p><p>  bname.setFont(new Font("Dialog",0,12));</p><p>  bno.setText(" 索書號 :");</p><p>  bno.se

101、tFont(new Font("Dialog",0,12));</p><p>  bnum.setText("數(shù)量:");</p><p>  bnum.setFont(new Font("Dialog",0,12));</p><p>  author.setText("作者:");

102、</p><p>  author.setFont(new Font("Dialog",0,12));</p><p>  publisher.setText(" 出版社 :");</p><p>  publisher.setFont(new Font("Dialog",0,12));</p>

103、;<p>  a.add(bname);</p><p>  a.add(tname);</p><p>  b.add(bno);</p><p>  b.add(tno);</p><p>  c.add(bnum);</p><p>  c.add(tnum);</p>&l

104、t;p>  d.add(author);</p><p>  d.add(tauthor);</p><p>  e.add(publisher);</p><p>  e.add(tpublisher);</p><p>  f.add(addbt);</p><p>  f.add(yesbt);<

105、/p><p><b>  add(a);</b></p><p><b>  add(b);</b></p><p><b>  add(c);</b></p><p><b>  add(d);</b></p><p><b&g

106、t;  add(e);</b></p><p><b>  add(f);</b></p><p>  setLayout(new GridLayout(8,1));</p><p>  addbt.addActionListener(this);</p><p>  yesbt.addActionList

107、ener(this);</p><p>  setSize(500,300);</p><p>  setLocation(400,150);</p><p><b>  }</b></p><p>  public void actionPerformed(ActionEvent e)</p><p

108、><b>  {</b></p><p>  String bname,bno,author,publisher;</p><p><b>  int bnum;</b></p><p>  if(e.getActionCommand()=="確定")</p><p>  

109、this.dispose();</p><p>  if(e.getActionCommand()=="添加")</p><p><b>  {</b></p><p>  bname=tname.getText();</p><p>  bno=tno.getText();</p>&

110、lt;p>  author=tauthor.getText();</p><p>  publisher=tpublisher.getText();</p><p>  bnum=Integer.parseInt(tnum.getText());</p><p>  String sqlstr1="select bno from book"

111、;</p><p>  rs=db.getResult(sqlstr1);</p><p><b>  try{</b></p><p>  while(rs.next())</p><p><b>  {</b></p><p>  if(rs.getString(1

112、).trim().equals(bno))</p><p><b>  {</b></p><p>  JOptionPane.showMessageDialog(null,"此書號已存在,請重新輸入索書號!");</p><p><b>  }</b></p><p><

113、b>  else</b></p><p><b>  {break;}</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  catch(Exception pe) </p><p>

114、;<b>  { </b></p><p>  pe.printStackTrace(); </p><p><b>  } </b></p><p>  String sqlstr="insert into book (bno,bname,bnum,author,publisher) valu

115、es ('"+bno+"','"+bname+"','"+bnum+"','"+author+"','"+publisher+"')";</p><p>  boolean result=db.updateSql(sqlstr

116、);</p><p>  db.closeConnection();</p><p>  if(result)</p><p><b>  {</b></p><p>  JOptionPane.showMessageDialog(null,"添加書籍成功!");</p><p&g

117、t;<b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  JOptionPane.showMessageDialog(null,"添加書籍失敗!");</p><p><b&g

118、t;  }}}}</b></p><p><b>  刪除圖書信息</b></p><p>  import java.awt.*;</p><p>  import java.awt.event.*;</p><p>  import javax.swing.*;</p><p> 

119、 import javax.swing.event.*;</p><p>  import java.sql.*;</p><p>  public class DeleteBook extends JFrame implements ActionListener </p><p>  { MainWindow mw=new MainWindow();<

120、/p><p>  DataBaseManger db=new DataBaseManger();</p><p>  ResultSet rs;</p><p>  JLabel bno=new JLabel("<html><font color=#000000 size='4'>請輸入要刪除的圖書索引號:</fo

121、nt>",SwingConstants.CENTER);</p><p><b>  JLabel L;</b></p><p>  JTextField tno=new JTextField(10);</p><p>  JTable table;</p><p>  JButton delbt=new

122、 JButton("刪除");</p><p>  JButton yesbt=new JButton("確定");</p><p>  JPanel p1=new JPanel();</p><p>  JPanel p2=new JPanel();</p><p>  public DeleteBo

123、ok()</p><p>  { super("刪除圖書");</p><p>  Container c=getContentPane();</p><p>  p1.add(bno);</p><p>  p1.add(tno);</p><p>  c.add(p1,BorderLa

124、yout.NORTH);</p><p>  p2.add(delbt);</p><p>  p2.add(yesbt);</p><p>  c.add(p2,BorderLayout.SOUTH);</p><p>  delbt.addActionListener(this);</p><p>  yesbt

125、.addActionListener(this);</p><p>  setSize(400,300);</p><p>  setLocation(400,150);</p><p>  JPanel p=new JPanel();</p><p>  p.setLayout(new BorderLayout());}</p>

126、;<p>  public void actionPerformed(ActionEvent e)</p><p>  { String bno;</p><p>  if(e.getActionCommand()=="確定")</p><p>  this.dispose();</p><p>  

127、if(e.getActionCommand()=="刪除")</p><p>  { bno=tno.getText();</p><p>  String sqlstr="delete bno from book where bno='"+bno+"'";</p><p>  b

128、oolean result=db.updateSql(sqlstr);</p><p>  db.closeConnection();</p><p>  if(result)</p><p>  {JOptionPane.showMessageDialog(null,"刪除書籍成功!");}</p><p><b&

129、gt;  else</b></p><p>  {JOptionPane.showMessageDialog(null,"刪除書籍失敗!");</p><p><b>  }}}}</b></p><p><b>  更新圖書信息</b></p><p>  impo

130、rt java.awt.*;</p><p>  import java.awt.event.*;</p><p>  import javax.swing.*;</p><p>  import javax.swing.event.*;</p><p>  import java.sql.*;</p><p>  p

131、ublic class UpdateBook extends JFrame implements ActionListener </p><p>  { MainWindow mw=new MainWindow();</p><p>  DataBaseManger db=new DataBaseManger();</p><p>  ResultSet r

132、s;</p><p>  JPanel a,b,c,d,e,f;</p><p>  JLabel bname=new JLabel();</p><p>  JLabel bno=new JLabel();</p><p>  JLabel bnum=new JLabel();</p><p>  JLabel au

133、thor=new JLabel();</p><p>  JLabel publisher=new JLabel();</p><p>  JTextField tname=new JTextField(20);</p><p>  JTextField tno=new JTextField(20);</p><p>  JTextField

134、 tnum=new JTextField(20);</p><p>  JTextField tauthor=new JTextField(20);</p><p>  JTextField tpublisher=new JTextField(20);</p><p>  JButton addbt=new JButton("更新");</

135、p><p>  JButton yesbt=new JButton("確定");</p><p>  JPanel p3=new JPanel();</p><p>  public UpdateBook()</p><p>  { super("更新圖書");</p><p>

136、  a=new JPanel();</p><p>  b=new JPanel();</p><p>  c=new JPanel();</p><p>  d=new JPanel();</p><p>  e=new JPanel();</p><p>  f =new JPanel();</p&

溫馨提示

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

評論

0/150

提交評論