版權(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ù)原理課程設(shè)計(jì)</p><p><b> 報(bào) 告 書(shū)</b></p><p> 課 題 名 圖書(shū)信息管理系統(tǒng) </p><p><b> 目 錄</b></p><p> 一、前言................................
2、..............................2</p><p> 二、概述..............................................................2</p><p> 2.1開(kāi)發(fā)目的.......................................................2</p>&
3、lt;p> 三、需求分析..........................................................2</p><p> 3.1可行性分析.....................................................2</p><p> 3.1.1技術(shù)可行性...........................
4、....................2</p><p> 3.1.2經(jīng)濟(jì)可行性...............................................3</p><p> 3.1.3管理可行性...............................................3</p><p> 3.2系統(tǒng)目標(biāo).......
5、................................................3</p><p> 3.3系統(tǒng)應(yīng)該具備的功能.............................................3</p><p> 3.4系統(tǒng)結(jié)構(gòu)圖.....................................................4</
6、p><p> 概念設(shè)計(jì).........................................................5</p><p> 邏輯設(shè)計(jì).........................................................9</p><p> 物理設(shè)計(jì)............................
7、.............................9</p><p> 5.1表命令........................................................9</p><p> 5.2表結(jié)構(gòu)圖.....................................................13</p><p&g
8、t; 代碼實(shí)現(xiàn)........................................................13</p><p> 6.1數(shù)據(jù)庫(kù)連接...................................................13</p><p> 6.2增加一條圖書(shū)記錄....................................
9、.........14</p><p> 6.3刪除一條圖書(shū)記錄.............................................16</p><p> 6.4修改一條圖書(shū)記錄.............................................17</p><p> 6.5查詢一條圖書(shū)記錄.............
10、................................18</p><p> 八、結(jié)束語(yǔ)..........................................................22</p><p><b> 前言</b></p><p> 近年來(lái),隨著我國(guó)市場(chǎng)經(jīng)濟(jì)的迅速發(fā)展和人們生活水平的不斷提高,以
11、及計(jì)算機(jī)的普及使用,圖書(shū)館藏書(shū)的數(shù)目逐漸增大,這也是挑戰(zhàn)了圖書(shū)管理方面的技術(shù),以前的人工管理方式已經(jīng)不再適應(yīng)現(xiàn)在的環(huán)境,取而代之的是先進(jìn)的圖書(shū)管理系統(tǒng),提高了圖書(shū)館的工作效率,為想要借書(shū)和還書(shū)的人提供更好的服務(wù)。</p><p><b> 1、概述</b></p><p><b> 1.1 開(kāi)發(fā)目的</b></p><p&
12、gt; 圖書(shū)信息管理工作面對(duì)大量的可模塊化處理的信息,是當(dāng)今信息革命的一個(gè)重要陣地。我們小組開(kāi)發(fā)圖書(shū)管理信息系統(tǒng)就是采用現(xiàn)代化的信息管理方式代替手工管理方式,提高圖書(shū)管理工作效率,做到信息的規(guī)范管理,科學(xué)統(tǒng)計(jì)和快速查詢,讓圖書(shū)館更好的為學(xué)校、社會(huì)服務(wù)。</p><p><b> 2、需求分析</b></p><p><b> 2.1可行性分析</
13、b></p><p> 2.1.1技術(shù)可行性</p><p> 就技術(shù)力量來(lái)說(shuō),我們小組可以完成此次開(kāi)發(fā)工作。開(kāi)發(fā)過(guò)程中會(huì)出現(xiàn)許多問(wèn)題,有我們預(yù)想之中的,也有一些沒(méi)有在我們預(yù)想中,但我們有信心克服一切困難。我們小組各成員已經(jīng)學(xué)習(xí)了MySQL,SQL,對(duì)網(wǎng)絡(luò)技術(shù)和操作系統(tǒng)也有系統(tǒng)的了解,熟悉計(jì)算機(jī)原理,能解決常見(jiàn)的硬件故障和硬件選擇。</p><p> 2
14、.1.2經(jīng)濟(jì)可行性</p><p> 目標(biāo)系統(tǒng)開(kāi)發(fā)需求比較低,加上具有成熟的軟硬件環(huán)境,所以在軟硬件的支出上十分有限。而且,目標(biāo)系統(tǒng)并不是十分的復(fù)雜,開(kāi)發(fā)的周期較短,人員有限。當(dāng)系統(tǒng)開(kāi)發(fā)完實(shí)際運(yùn)行后,將很大程度上提高計(jì)算機(jī)的功能,在為使用者帶來(lái)便利的同時(shí)也為系統(tǒng)的進(jìn)一步推廣創(chuàng)造了條件。</p><p> 2.1.3管理可行性</p><p> 整個(gè)系統(tǒng)由于是自
15、行開(kāi)發(fā),自行使用,所以很方便管理使用。</p><p><b> 2.2系統(tǒng)目標(biāo)</b></p><p> 圖書(shū)管理信息系統(tǒng)是典型的信息管理系統(tǒng),其開(kāi)發(fā)主要包括后臺(tái)數(shù)據(jù)庫(kù)的建立和維護(hù)以及前端應(yīng)用程序的開(kāi)發(fā)兩個(gè)方面。對(duì)于前者要求建立起數(shù)據(jù)一致性和完整性強(qiáng),數(shù)據(jù)安全性好的庫(kù)。而對(duì)于后者則要求應(yīng)用程序功能完備,易使用等特點(diǎn)。系統(tǒng)開(kāi)發(fā)的總體任務(wù)是實(shí)現(xiàn)各種信息的系統(tǒng)化,規(guī)范
16、化和自動(dòng)化。</p><p> 2.3 系統(tǒng)應(yīng)該具備的功能</p><p> ?、僮x者基本信息的輸入,包括借書(shū)證編號(hào)、讀者姓名、讀者性別等。</p><p> ?、谧x者基本信息的查詢、修改,包括讀者借書(shū)證編號(hào)、讀者姓名、讀者性別等。</p><p> ?、蹠?shū)籍類別標(biāo)準(zhǔn)的制定、類別信息的輸入,包括類別編號(hào)、類別名稱。</p>&
17、lt;p> ?、軙?shū)籍類別信息的查詢、修改,包括類別編號(hào)、類別名稱。</p><p> ?、輹?shū)籍庫(kù)存信息的輸入,包括書(shū)籍編號(hào)、書(shū)籍名稱、書(shū)籍類別、作者姓名、出版社名稱、出版日期、登記日期。</p><p> ?、迺?shū)籍庫(kù)存信息的查詢,修改,包括書(shū)籍編號(hào)、書(shū)籍名稱、書(shū)籍類別、作者姓名、出版社名稱、出版日期登記日期等。</p><p> ?、呓钑?shū)信息的輸入,包括讀者借
18、書(shū)證編號(hào)、書(shū)籍編號(hào)、借書(shū)日期。</p><p> ?、嘟钑?shū)信息的查詢、修改,包括借書(shū)證編號(hào)、借書(shū)證編號(hào)、讀者姓名、書(shū)籍編號(hào)、書(shū)籍名稱、借書(shū)日期等。</p><p> ?、徇€書(shū)信息的輸入,包括借書(shū)證編號(hào)、書(shū)籍編號(hào)、還書(shū)日期。 </p><p> ?、膺€書(shū)信息的查詢和修改,包括還書(shū)讀者借書(shū)證編號(hào)、讀者姓名、書(shū)籍編號(hào)、書(shū)籍名稱、借書(shū)日期、還書(shū)日期等。</p&g
19、t;<p> ?、铣谶€書(shū)罰款輸入,還書(shū)超出期限包括超出期限還書(shū)的讀者借書(shū)證號(hào),書(shū)籍編號(hào),罰款金額。</p><p> ?、谐谶€書(shū)罰款查詢,刪除,包括讀者借書(shū)證編號(hào)、讀者姓名、書(shū)籍編號(hào)、書(shū)籍名稱,罰款金額等。</p><p> ⒀管理員管理:包括創(chuàng)建讀者用戶信息、刪除讀者用戶信息、添加圖書(shū)信息、刪除圖書(shū)信息。</p><p> ?、页?jí)管理員管理:
20、包括創(chuàng)建管理員用戶信息、刪除管理員用戶信息、創(chuàng)建讀者用戶信息、刪除讀者用戶信息、添加圖書(shū)信息、刪除圖書(shū)信息。</p><p><b> 2.4 系統(tǒng)結(jié)構(gòu)圖</b></p><p> ?。ǜ鶕?jù)需求分析,圖書(shū)信息管理系統(tǒng)的結(jié)構(gòu)圖如下:)</p><p><b> 3、概念設(shè)計(jì)</b></p><p>
21、; 所要實(shí)現(xiàn)的功能設(shè)計(jì),可能建立它們之間的關(guān)系,進(jìn)而實(shí)現(xiàn)邏輯結(jié)構(gòu)功能。圖書(shū)管理信息系統(tǒng)可以劃分的實(shí)體有:書(shū)籍類別信息實(shí)體、讀者信息實(shí)體、書(shū)籍信息實(shí)體、借閱記錄信息實(shí)體,歸還記錄信息實(shí)體。用E-R圖一一描述這些實(shí)體。</p><p><b> ?、兕悇e實(shí)體圖:</b></p><p><b> ?、谧x者信息實(shí)體圖:</b></p>
22、<p><b> ?、酃芾韱T實(shí)體圖</b></p><p><b> ?、艹?jí)管理員實(shí)體圖</b></p><p><b> ?、輹?shū)籍實(shí)體圖:</b></p><p> ?、藿栝営涗浵⑿艑?shí)體圖:</p><p> ?、邭w還記錄信息實(shí)體圖:</p><
23、;p><b> ?、嗔P款信息實(shí)體圖:</b></p><p> ?、峥偟男畔?shí)體E-R圖:</p><p><b> 4、邏輯設(shè)計(jì)</b></p><p> (1)書(shū)籍類別(類別編號(hào),類別名)</p><p> (2)讀者(借書(shū)證編號(hào),讀者姓名,讀者性別,讀者種類,登記時(shí)期, 可借書(shū)數(shù)
24、 ,已借書(shū)數(shù),逾期未還書(shū)數(shù))</p><p> (3) 管理員(管理員編號(hào),管理員姓名,管理員密碼,管理員權(quán)限)</p><p> (4) 超級(jí)管理員(管理員編號(hào),管理員姓名,管理員密碼,管理員權(quán)限)</p><p> (5)書(shū)籍(書(shū)籍編號(hào),書(shū)籍名稱,書(shū)籍類別,書(shū)記作者,出版社名稱, 出版日期,登記日期)</p><p> (6)借
25、閱(借書(shū)證編號(hào),書(shū)籍編號(hào),讀者借書(shū)時(shí)間)</p><p> (7)還書(shū)(借書(shū)證編號(hào),書(shū)籍編號(hào),讀者還書(shū)時(shí)間)</p><p> (8)罰款(借書(shū)證編號(hào),讀者姓名,借書(shū)證編號(hào),書(shū)籍編號(hào),讀者借書(shū) 時(shí)間)</p><p><b> 5、 物理設(shè)計(jì)</b></p><p><b> 表命令:</b&g
26、t;</p><p><b> ?。?)創(chuàng)建數(shù)據(jù)庫(kù)</b></p><p> CREATE DATABASE librarysystem</p><p><b> ON </b></p><p><b> (</b></p><p> NAME
27、= librarysystem,</p><p> FILENAME = 'd:\librarysystem.mdf',</p><p> SIZE = 10,</p><p> MAXSIZE = 50,</p><p> FILEGROWTH = 5 )</p><p><b>
28、 LOG ON</b></p><p><b> ( </b></p><p> NAME = 'library',</p><p> FILENAME = 'e:\librarysystem.ldf',</p><p> SIZE = 5MB,</p>
29、<p> MAXSIZE = 25MB,</p><p> FILEGROWTH = 5MB </p><p><b> )</b></p><p> ?。?)書(shū)本類別表建立</p><p> create table book_style</p><p><b>
30、( </b></p><p> bookstyleno varchar(30) primary key,</p><p> bookstyle varchar(30)</p><p><b> )</b></p><p><b> (3)創(chuàng)建書(shū)庫(kù)表</b></p>
31、<p> create table system_books</p><p><b> ( </b></p><p> bookid varchar(20) primary key,</p><p> bookname varchar(30) Not null, </p><p> bookstyle
32、no varchar(30) Not null,</p><p> bookauthor varchar(30),</p><p> bookpub varchar(30) ,</p><p> bookpubdate datetime,</p><p> bookindate datetime ,</p><p&
33、gt; isborrowed bit,</p><p> foreign key (bookstyleno) references book_style (bookstyleno),</p><p><b> )</b></p><p><b> ?。?)借書(shū)證表建立</b></p><p>
34、 create table system_readers </p><p><b> ( </b></p><p> readerid varchar(9)primary key,</p><p> readername varchar(9)not null ,</p><p> readersex varch
35、ar(2) not null,</p><p> readertype varchar(10),</p><p> regdate datetime,</p><p> booktotal int,</p><p> borrowednum int,</p><p> overduenoreturnnum i
36、nt </p><p><b> )</b></p><p> ?。?)借書(shū)記錄表建立</p><p> create table borrow_record</p><p><b> ( </b></p><p> bookid varchar(20) prima
37、ry key,</p><p> readerid varchar(9),</p><p> borrowdate datetime,</p><p> foreign key (bookid) references system_books(bookid),</p><p> foreign key (readerid) refer
38、ences system_readers(readerid),</p><p><b> )</b></p><p> ?。?)還書(shū)記錄表建立</p><p> create table return_record</p><p><b> ( </b></p><p>
39、; bookid varchar(20) primary key,</p><p> readerid varchar(9),</p><p> returndate datetime,</p><p> foreign key (bookid) references system_books(bookid),</p><p> f
40、oreign key (readerid) references system_readers(readerid)</p><p><b> ) </b></p><p><b> (7)罰款單表建立</b></p><p> create table reader_fee</p><p>&
41、lt;b> ( </b></p><p> readerid varchar(9)not null,</p><p> readername varchar(9)not null ,</p><p> bookid varchar(20) primary key,</p><p> bookname varchar
42、(30) Not null, </p><p> bookfee smallmoney,</p><p> borrowdate datetime,</p><p> foreign key (bookid) references system_books(bookid),</p><p> foreign key (readerid
43、) references system_readers(readerid)</p><p><b> )</b></p><p> (8) 管理員表建立</p><p> create table system_Administrator </p><p><b> (</b></p&
44、gt;<p> administratorid varchar(9)primary key,</p><p> administratorname varchar(9)not null ,</p><p> administratorpassword varchar(2) not null,</p><p> administratorper
45、mission varchar(10)</p><p><b> )</b></p><p><b> (9) 索引的創(chuàng)建</b></p><p> create index bookstyle_index_style on book_style(bookstyle)</p><p> cr
46、eate index borrow_record_index_readerid on borrow_record(readerid)</p><p> create index reader_fee_index_readerid on reader_fee (readerid)</p><p> create index return_record_index_readerid
47、on return_record(readerid)</p><p> create index system_books_index_bookname on system_books(bookname)</p><p> create index system_books_index_styleno on system_books(bookstyleno)</p>
48、<p> create index system_books_index_bookauthor on system_books(bookauthor)</p><p> 表3-1 book_sytle 書(shū)籍類別信息表</p><p> 表3-2 system_readers讀者信息表格</p><p> 表3-3 system_book書(shū)籍信
49、息表</p><p><b> 續(xù)表3-3</b></p><p> 表3-4 borrow_record 借閱記錄信息表</p><p> 表3-5 return_record 借閱記錄信息表</p><p> 表3-6 reader_fee 罰款記錄信息表</p><p> 表3-7
50、system_Administrator管理員信息表</p><p> 表3-8 system_Super_Administrator管理員信息表</p><p><b> 表結(jié)構(gòu)圖:</b></p><p><b> 6、代碼實(shí)現(xiàn)</b></p><p><b> 1)數(shù)據(jù)庫(kù)的
51、連接:</b></p><p> import java.sql.*; </p><p> import javax.swing.JOptionPane; </p><p> public class Query </p><p><b> { </b></p><p> p
52、ublic static Connection conection = null; </p><p> static Connection getConnection()</p><p> {//連接 MySQL 數(shù)據(jù)庫(kù) </p><p><b> try{ </b></p><p> Class.forNam
53、e("org.gjt.mm.mysql.Driver");//加載驅(qū)動(dòng) </p><p> conection = DriverManager.getConnection</p><p> (//連接字符串 "jdbc:mysql://localhost:3306/book","root","123");
54、</p><p> System.out.println("數(shù)據(jù)庫(kù)連接成功"); </p><p> }catch(java.lang.ClassNotFoundException classnotfound)</p><p><b> { </b></p><p> classnotfoun
55、d.printStackTrace();//驅(qū)動(dòng)未找到 </p><p><b> }</b></p><p> catch(java.sql.SQLException sql)</p><p><b> { </b></p><p> sql.printStackTrace();//SQL
56、 執(zhí)行時(shí)發(fā)生異常,打印棧信息 </p><p><b> }</b></p><p> return conection; </p><p><b> } </b></p><p> 2)增加一條圖書(shū)記錄:</p><p> public static boolea
57、n Insert(Book aBook) </p><p><b> {</b></p><p> Connection connect=getConnection();//得到連接 </p><p> boolean res=false; </p><p><b> try { </b>
58、</p><p> Statement stmt = connect.createStatement();//查詢集 </p><p> String sql = "select * from book where BID='"+aBook.getBID()+"'"; </p><p> ResultSe
59、t rs=stmt.executeQuery(sql);//執(zhí)行 SQL 命令,返回結(jié)果集 </p><p> if (rs.next())//圖書(shū)編號(hào)存在 </p><p> { res=false; </p><p> JOptionPane.showMessageDialog(null,"學(xué)生信息插入失敗,該 學(xué)生 ID 號(hào)已存在&qu
60、ot;,"警告",JOptionPane.WARNING_MESSAGE); </p><p> rs.close(); </p><p> stmt.close(); </p><p> } else{ //不存在 </p><p> String sqlString="insert into book
61、 values('"+aBook.getBID()+"','"+aBook.getBname()+"','"+</p><p> aBook.getBauthor()+"','"+aBook.getPress()+"','"+</p>
62、;<p> aBook.getBinfo()+"','"+aBook.getYear()+"-"+</p><p> aBook.getMonth()+"-"+aBook.getDay()+"','"+ aBook.getBclass()+"')"; &l
63、t;/p><p> res =stmt.execute(sqlString); </p><p> res=true; </p><p><b> if(res) </b></p><p><b> { </b></p><p> JOptionPane.showMes
64、sageDialog(null," 圖 書(shū) 信 息 插 入 成 功","成功",JOptionPane.INFORMATION_MESSAGE); rs.close(); </p><p><b> } else{ </b></p><p> res=false; </p><p> JOpti
65、onPane.showMessageDialog(null,"圖書(shū)信息插入失敗", "警告",JOptionPane.WARNING_MESSAGE); rs.close(); </p><p><b> } </b></p><p><b> } </b></p><p>
66、 }catch (SQLException e) //捕獲異常 </p><p><b> { </b></p><p> res=false; </p><p> System.out.print("Error loading Mysql Driver!"); e.printStackTrace(); </
67、p><p><b> } </b></p><p> return res; </p><p><b> } </b></p><p> 3)刪除一條圖書(shū)記錄:</p><p> public static boolean delBook(String bid) <
68、;/p><p><b> {</b></p><p> Connection connect=getConnection(); </p><p> boolean res=false; </p><p><b> try { </b></p><p> Stateme
69、nt stmt = connect.createStatement(); </p><p> String sql = "select * from book where Bid='"+bid+"'"; </p><p> ResultSet rs=stmt.executeQuery(sql); </p><p
70、> if (rs.next()) </p><p><b> { </b></p><p> String sqlString="delete from book where Bid='"+bid+"'"; stmt.executeUpdate(sqlString); </p><
71、;p> JOptionPane.showMessageDialog(null,"圖書(shū)信息刪除成功", "成功",JOptionPane.INFORMATION_MESSAGE); </p><p> res=true; </p><p> rs.close(); </p><p> stmt.close()
72、; </p><p><b> } </b></p><p><b> else{ </b></p><p> JOptionPane.showMessageDialog(null,"圖書(shū)信息刪除失敗,該 圖書(shū) ID 號(hào)不存在","警告",JOptionPane.WARNIN
73、G_MESSAGE); </p><p> res=false; </p><p> rs.close(); </p><p> stmt.close(); </p><p><b> } </b></p><p> }catch (SQLException e) </p>
74、;<p><b> { </b></p><p> JOptionPane.showMessageDialog(null,"圖書(shū)信息刪除失敗", "成功",JOptionPane.INFORMATION_MESSAGE); </p><p> res=false;</p><p>
75、; System.out.print("Error loading Mysql Driver!"); </p><p> e.printStackTrace();</p><p><b> } </b></p><p> return res;</p><p><b> } &
76、lt;/b></p><p><b> 4)修改圖書(shū)信息:</b></p><p> public static boolean modifyBook(Book oldBook) </p><p> {Connection connect=getConnection(); </p><p> boolea
77、n flag=false; </p><p><b> try { </b></p><p> Statement stmt = connect.createStatement(); //查詢集 </p><p> String sqlString="update book set Bname='"+oldB
78、ook.getBname()+"',</p><p> Bauthor='"+oldBook.getBauthor() +"', Press='"+oldBook.getPress()+"', </p><p> BInfo='"+oldBook.getBinfo()+"
79、;',BDate='"+oldBook.getYear()+"-"+</p><p> oldBook.getMonth()+"-"+oldBook.getDay()+"',Bclass='"+</p><p> oldBook.getBclass()+"' <
80、/p><p> where BID='"+oldBook.getBID()+"'"; stmt.executeUpdate(sqlString); </p><p> JOptionPane.showMessageDialog(null,"圖書(shū)信息修改成功", "成功",JOptionPane.INF
81、ORMATION_MESSAGE); </p><p> flag=true; </p><p> }catch (SQLException e) //捕獲錯(cuò)誤 </p><p> { JOptionPane.showMessageDialog(null,"圖書(shū)信息修改失敗", "警告",JOptionPa
82、ne.WARNING_MESSAGE);</p><p> flag=false; </p><p> System.out.print("Error loading Mysql Driver!");</p><p> e.printStackTrace(); </p><p><b> } </b
83、></p><p> return flag; </p><p><b> } </b></p><p> 5)修改一條圖書(shū)記錄并將結(jié)果用表格顯示出來(lái):</p><p><b> public </b></p><p> {javax.swing.List
84、SelectionModel; </p><p> javax.swing.RowSorter; javax.swing.table.DefaultTableModel; javax.swing.table.TableRowSorter; </p><p> class BookInfoQuery extends JFrame </p><p> Borde
85、rLayout borderLayout1 = new BorderLayout();//布局方式 </p><p> JSplitPane jSplitPane1 = new JSplitPane();//分割面板 </p><p> JScrollPane jScrollPane1 = new JScrollPane();//滾動(dòng)面板,用于放置表格 </p><
86、p> JPanel jPanel1 = new JPanel();//面板 </p><p> JTable jTable1 = new JTable();//表格</p><p> DefaultTableModel tablemodel = null;//默認(rèn)表格模型 </p><p> JPanel jPanel3 = new JPanel();
87、//面板 </p><p> GridLayout gridLayout1 = new GridLayout();// 網(wǎng)格布局方式 </p><p> JButton jBexit = new JButton();//退出按鈕 </p><p> ListSelectionModel selectionMode=null; </p><p
88、> public BookInfoQuery(String bID,String bname,String bauthor, String press,</p><p> String bInfo,String year,String month,String day,String bclass) </p><p> { getContentPane().setLayout(b
89、orderLayout1);//設(shè)置布局方式 </p><p> String[] name = {"圖書(shū)編號(hào)","圖書(shū)名稱","作者","出版社","圖書(shū)簡(jiǎn)介 ","出版時(shí)間", "類別"}; </p><p> String sqlStr =
90、"select * from book where Year(BDate)>1900"; </p><p> if(bID!=null)//查詢時(shí)如果編號(hào)不為空 </p><p><b> { </b></p><p> sqlStr+=" and BID='"+bID+"
91、'"; </p><p><b> } </b></p><p> if(bname!=null)//查詢時(shí)如果圖書(shū)名不為空 </p><p><b> { </b></p><p> sqlStr+=" and Bname like '%"+b
92、name+"%'";//模糊查詢 </p><p><b> } </b></p><p> if(bauthor!=null)//查詢時(shí)如果作者不為空 </p><p><b> { </b></p><p> sqlStr+=" and Bautho
93、r like'%"+bauthor+"%'";//模糊查詢 </p><p><b> } </b></p><p> if(press!=null)//查詢時(shí)如果出版社不為空 </p><p><b> { </b></p><p> sqlS
94、tr+=" and Press like '%"+press+"%'";//模糊查詢 </p><p><b> } </b></p><p> if(bInfo!=null)//查詢時(shí)如果圖書(shū)信息不為空 </p><p><b> { </b></p&
95、gt;<p> sqlStr+=" and Binfo like '%"+bInfo+"%'";//模糊查詢 </p><p><b> } </b></p><p> if(year!=null)//出版年份不為空 </p><p><b> { <
96、/b></p><p> sqlStr+=" and Year(BDate)"+year+" ";//按條件查詢 </p><p><b> } </b></p><p> if(month!=null)//出版月份不為空 </p><p><b> { &
97、lt;/b></p><p> sqlStr+=" and Month(BDate)"+month+" ";//按條件查詢 </p><p><b> }</b></p><p> if(day!=null)//出版日不為空 </p><p><b> {
98、</b></p><p> sqlStr+=" and Day(BDate)"+day+" ";//按條件查詢 </p><p><b> } </b></p><p> if(bclass!=null)// 圖書(shū)類別不為空 </p><p><b>
99、 { </b></p><p> sqlStr+=" and Bclass like '%"+bclass+"%'";//模糊查詢 </p><p><b> } </b></p><p> sqlStr+=" order by BDate desc"
100、;//按出版日期降序排序 </p><p> ToTable bdt = new ToTable(); </p><p> tablemodel = bdt.getTableModel(name,sqlStr); </p><p> jTable1.setModel(tablemodel); jTable1.setAutoResizeMode(JTable.
101、AUTO_RESIZE_SUBSEQUENT_COLUMN S);</p><p> //讓其它的列也跟隨變動(dòng) </p><p> jTable1.setEnabled(true);//設(shè)置表格可用 </p><p> jTable1.setCellSelectionEnabled(true); </p><p> jTable1.s
102、etBackground(Color.pink);//設(shè)置表格背景顏色 selectionMode=jTable1.getSelectionModel();</p><p> selectionMode.setSelectionMode(ListSelectionModel.SINGLE_SELEC TION); jTable1.setRowHeight(24);//設(shè)置表格高度 </p>&
103、lt;p> RowSorter<DefaultTableModel> sorter TableRowSorter<DefaultTableModel>(tablemodel)= newjTable1.setRowSorter(sorter);</p><p><b> //表格排序過(guò)濾 </b></p><p> jScrollP
104、ane1.setHorizontalScrollBarPolicy(JScrollPane.</p><p> HORIZONTAL_SCROLLBAR_ALWAYS); </p><p> jScrollPane1.setVerticalScrollBarPolicy(JScrollPane. VERTICAL_SCROLLBAR_ALWAYS); </p>
105、<p> jBexit.setText("退出"); </p><p> jBexit.addActionListener(new ActionListener() </p><p><b> { </b></p><p> public void actionPerformed(ActionEvent a
106、rg0)</p><p> { int result = JOptionPane.showOptionDialog(null,"是否退 出圖書(shū)信息查詢?","系統(tǒng)提示", JOptionPane.YES_NO_OPTION,JOptionPane.QUESTION_MESSAGE, null,new String[] {"是","否&
107、quot;},"否"); </p><p> if (result == JOptionPane.YES_OPTION) </p><p><b> { </b></p><p> dispose();//隱藏 </p><p><b> }</b></p>
108、<p><b> } </b></p><p><b> }</b></p><p> jPanel1.add(jBexit); </p><p> jScrollPane1.getViewport().add(jTable1);//將表格添加至滾動(dòng)面板中 jSplitPane1.add(jPanel
109、1, JSplitPane.BOTTOM); </p><p> jSplitPane1.resetToPreferredSizes();</p><p> jSplitPane1.add(jScrollPane1, JSplitPane.TOP); </p><p> this.getContentPane().add(jSplitPane1, java.a
110、wt.BorderLayout.CENTER); this.getContentPane().add(jPanel1, java.awt.BorderLayout.SOUTH); this.add(jSplitPane1); </p><p> setSize(800,640); </p><p> setVisible(true); </p><p>
111、setTitle("按復(fù)合條件進(jìn)行查詢"); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);</p><p><b> } </b></p><p><b> } </b></p><p><b> 7、結(jié)束語(yǔ)</b><
112、/p><p> 通過(guò)對(duì)圖書(shū)信息管理系統(tǒng)的設(shè)計(jì),我們對(duì)數(shù)據(jù)庫(kù)的理論知識(shí)有了更多的認(rèn)識(shí),對(duì)需求分析的重要性、對(duì)一個(gè)系統(tǒng)的各部門(mén)的工作流程細(xì)節(jié)有了更深入的了解,對(duì)概念設(shè)計(jì)的步驟掌握的更加清晰,對(duì)分析過(guò)程中的原則要求有了更透徹的認(rèn)識(shí),使得我們對(duì)數(shù)據(jù)庫(kù)的整體設(shè)計(jì)有了更好的把握。</p><p> 課程設(shè)計(jì)中,設(shè)計(jì)一個(gè)圖書(shū)館管理系統(tǒng),其中包含了對(duì)圖書(shū)基本信息的管理,借閱和還書(shū)信息管理等,上包含了圖書(shū)館
113、管理所要求的信息,能夠完成一定的數(shù)據(jù)管理功能。但總之在設(shè)計(jì)當(dāng)中我們學(xué)習(xí)到了許多東西,用到了很多的數(shù)據(jù)庫(kù)的理論知識(shí),增強(qiáng)了一定的實(shí)踐能里。</p><p> 系統(tǒng)的特色與不足,圖書(shū)館管理信息系統(tǒng)是日常生活中經(jīng)常接觸到的一個(gè)系統(tǒng)。系統(tǒng)除了基本功能外,增加了報(bào)表的功能。系統(tǒng)的不足之處就是對(duì)圖書(shū)預(yù)約功能的處理還有待完善,另外就是對(duì)圖書(shū)館刪除圖書(shū)的相關(guān)借閱信息是否需要保存還有待考慮。</p><p&g
溫馨提示
- 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ū)信息管理系統(tǒng)數(shù)據(jù)庫(kù)課程設(shè)計(jì)報(bào)告
- sql課程設(shè)計(jì)---圖書(shū)信息管理系統(tǒng)數(shù)據(jù)庫(kù)設(shè)計(jì)
- 數(shù)據(jù)庫(kù)技術(shù)與應(yīng)用課程設(shè)計(jì)---圖書(shū)信息管理系統(tǒng)
- 課程設(shè)計(jì)--圖書(shū)信息管理系統(tǒng)
- 圖書(shū)信息管理系統(tǒng)課程設(shè)計(jì)
- 圖書(shū)信息管理系統(tǒng) 課程設(shè)計(jì)
- 課程設(shè)計(jì)---圖書(shū)信息管理系統(tǒng)
- 課程設(shè)計(jì)---圖書(shū)信息管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)高校圖書(shū)信息系統(tǒng)數(shù)據(jù)庫(kù)的設(shè)計(jì)與應(yīng)用
- 課程設(shè)計(jì)--- 圖書(shū)信息管理系統(tǒng)設(shè)計(jì)
- 課程設(shè)計(jì)---圖書(shū)信息管理系統(tǒng)設(shè)計(jì)
- 圖書(shū)信息管理系統(tǒng)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)---宿舍信息管理系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)--教室信息管理系統(tǒng).
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)--學(xué)生信息管理系統(tǒng)
- sql課程設(shè)計(jì)(圖書(shū)信息管理系統(tǒng))
- 圖書(shū)信息管理系統(tǒng)課程設(shè)計(jì)報(bào)告
- 圖書(shū)信息管理系統(tǒng)課程設(shè)計(jì)報(bào)告
- 圖書(shū)信息管理系統(tǒng)java課程設(shè)計(jì)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)---學(xué)生信息管理系統(tǒng)
評(píng)論
0/150
提交評(píng)論