欧美色欧美亚洲高清在线观看,国产特黄特色a级在线视频,国产一区视频一区欧美,亚洲成a 人在线观看中文

  1. <ul id="fwlom"></ul>

    <object id="fwlom"></object>

    <span id="fwlom"></span><dfn id="fwlom"></dfn>

      <object id="fwlom"></object>

      c語(yǔ)言圖書(shū)管理系統(tǒng)

      時(shí)間:2019-05-14 02:20:45下載本文作者:會(huì)員上傳
      簡(jiǎn)介:寫(xiě)寫(xiě)幫文庫(kù)小編為你整理了多篇相關(guān)的《c語(yǔ)言圖書(shū)管理系統(tǒng)》,但愿對(duì)你工作學(xué)習(xí)有幫助,當(dāng)然你在寫(xiě)寫(xiě)幫文庫(kù)還可以找到更多《c語(yǔ)言圖書(shū)管理系統(tǒng)》。

      第一篇:c語(yǔ)言圖書(shū)管理系統(tǒng)

      C語(yǔ)言——圖書(shū)管理系統(tǒng)

      代碼部分: #include #include #include #pragma comment(lib,“l(fā)ibmysql.lib”)

      /*定義數(shù)據(jù)庫(kù)相關(guān)操作變量*/ MYSQL mysql;

      // MYSQL_RES *result;

      //定義結(jié)果集變量 MYSQL_ROW row;

      //定義行變量 char ch[2];

      void ShowAll();

      /*顯示所有的圖書(shū)信息*/ void AddBook();

      /*添加圖書(shū)信息*/ void ModifyBook();

      /*修改圖書(shū)信息*/ void DeleteBook();

      /*刪除圖書(shū)信息*/ void QueryBook();

      /*查詢圖書(shū)信息*/

      /*顯示菜單*/ void showmenu(){

      system(“cls”);

      printf(“nnnnn”);

      printf(“t╔═══════════════════════════╗n”);

      printf(“t║

      Welcome To Lemon Books System

      ║n”);

      printf(“t╠═══════════════════════════╣n”);

      printf(“t║t 1添加圖書(shū)信息

      ║n”);

      printf(“t║t 3刪除圖書(shū)信息

      ║n”);

      printf(“t║t 5退出

      ║n”);

      printf(“t╚═══════════════════════════╝n”);

      printf(“n

      ENTER YOUR CHOICE(1-6):”);

      }

      void inquire()/*詢問(wèn)用戶是否顯示主菜單*/ {

      printf(“t 顯示主菜單?(y/n):”);

      scanf(“%s”,ch);

      if(strcmp(ch,“Y”)==0||strcmp(ch,“y”)==0)/*判斷是否要顯示查找到的信息*/

      {

      showmenu();

      /*顯示菜單*/

      }

      else

      {

      exit(0);

      } }

      /*顯示主菜單,連接數(shù)據(jù)庫(kù)*/ int main(){

      int n;

      //定義變量

      存儲(chǔ)用戶輸入的編號(hào)

      mysql_init(&mysql);//初始化mysql結(jié)構(gòu)

      showmenu();

      /*顯示菜單*/

      scanf(“%d”,&n);/*輸入選擇功能的編號(hào)*/

      while(n)

      {

      switch(n)

      {

      case 1:

      ShowAll();

      /*調(diào)用顯示所有圖書(shū)數(shù)據(jù)的過(guò)程*/

      break;

      case 2:

      AddBook();

      /*添加圖書(shū)信息*/

      break;

      case 3:

      ModifyBook();

      /*修改圖書(shū)信息*/

      break;

      case 4:

      DeleteBook();

      /*刪除圖書(shū)信息*/

      break;

      case 5:

      QueryBook();

      /*查詢圖書(shū)信息*/

      break;

      case 6:

      exit(0);

      /*退出*/

      default:break;

      }

      scanf(“%d”,&n);

      } }

      void ShowAll()

      /*調(diào)用顯示所有圖書(shū)數(shù)據(jù)的過(guò)程*/ {

      /*連接數(shù)據(jù)庫(kù)*/

      if(!mysql_real_connect(&mysql,“127.0.0.1”,“root”,“111”,“db_books”,0,NULL,0))

      {

      printf(“nt 不能連接數(shù)據(jù)庫(kù)!n”);

      }

      else

      {

      /*數(shù)據(jù)庫(kù)連接成功*/

      if(mysql_query(&mysql,“select * from tb_book”))

      {

      //如果查詢失敗

      printf(“nt 查詢 tb_book 數(shù)據(jù)表失敗!n”);

      }

      else

      {

      result=mysql_store_result(&mysql);//獲得結(jié)果集

      if(mysql_num_rows(result)!=NULL)

      { //有記錄的情況,只有有記錄取數(shù)據(jù)才有意義

      printf(“t ════════════════════════════

      n”);

      printf(“t

      顯 示 所 有 圖 書(shū) 信 息

      n”);

      printf(“t ════════════════════════════ n”);

      printf(“t圖書(shū)編號(hào)

      圖書(shū)名

      作者

      出版社

      n”);

      printf(“t-------------------------n”);

      while((row=mysql_fetch_row(result)))

      {

      //取出結(jié)果集中記錄

      fprintf(stdout,“t

      %s

      %s

      %s

      %s

      n”,row[0],row[1],row[2],row[3]);//輸出這行記錄

      }

      printf(“t ════════════════════════════ n”);

      }

      else

      {

      printf(“nt 沒(méi)有記錄信息!n”);

      }

      mysql_free_result(result);

      //釋放結(jié)果集

      }

      mysql_close(&mysql);

      //釋放連接

      }

      inquire();

      /*詢問(wèn)是否顯示主菜單*/ }

      void AddBook()

      /*添加圖書(shū)信息*/ {

      int rowcount;

      /*結(jié)果集中的行數(shù)*/

      char id[10];

      /*編號(hào)*/

      char *bookname;

      char *author;

      char *bookconcern;

      char *sql;

      char dest[500] ={“

      ”};

      /*連接數(shù)據(jù)庫(kù)*/

      if(!mysql_real_connect(&mysql,“127.0.0.1”,“root”,“111”,“db_books”,0,NULL,0))

      {

      printf(“nt 不能連接數(shù)據(jù)庫(kù)!n”);

      }

      else

      {

      /*數(shù)據(jù)庫(kù)連接成功,插入數(shù)據(jù)*/

      printf(“t ════════════════════════════ n”);

      printf(“t

      添 加 圖 書(shū) 信 息

      n”);

      printf(“t ════════════════════════════ n”);

      if(mysql_query(&mysql,“select * from tb_book”))

      {

      //如果查詢失敗

      printf(“nt 查詢 tb_book 數(shù)據(jù)表失敗!n”);

      }

      else

      {

      result=mysql_store_result(&mysql);//獲得結(jié)果集

      rowcount=mysql_num_rows(result);//獲得行數(shù)

      row=mysql_fetch_row(result);

      //獲取結(jié)果集的行

      printf(“t 圖書(shū)編號(hào):”);

      scanf(“%s”,id);

      /*輸入圖書(shū)編號(hào)*/

      sql=“insert into tb_book(ID,bookname,author,bookconcern)values(”;

      strcat(dest,sql);

      strcat(dest,“'”);

      strcat(dest,id);

      strcat(dest,“', '”);

      if(mysql_num_rows(result)!=NULL)

      {

      /*判斷輸入的編號(hào)是否存在*/

      do

      {

      //存在相同編號(hào)

      if(!strcmp(id,row[0]))

      {

      // printf(“%s”,row[0]);

      printf(“nt 記錄存在,按任意鍵繼續(xù)!n”);

      getch();

      mysql_free_result(result);

      /*釋放結(jié)果集*/ mysql_close(&mysql);

      /*釋放連接*/

      inquire();

      /*詢問(wèn)是否顯示主菜單*/

      return;

      }

      }while(row=mysql_fetch_row(result));

      }

      bookname =(char*)malloc(50);

      author =(char*)malloc(50);

      bookconcern =(char*)malloc(50);

      //不存在相同的編號(hào)

      printf(“t 圖書(shū)名:”);

      scanf(“%s”,bookname);

      /*輸入圖書(shū)名*/

      strcat(dest,bookname);

      /*將圖書(shū)編號(hào)追加到sql語(yǔ)句后面*/

      printf(“t 作者:”);

      scanf(“%s”,author);

      /*輸入作者*/

      strcat(dest,“', '”);

      strcat(dest,author);

      printf(“t 出版社:”);

      scanf(“%s”,bookconcern);

      /*輸入出版社*/

      strcat(dest,“', '”);

      strcat(dest,bookconcern);

      strcat(dest,“')”);

      //printf(“%s”,dest);

      if(mysql_query(&mysql,dest)!=0)

      {

      fprintf(stderr,“t 不能插入記錄!”,mysql_error(&mysql));

      }

      else

      {

      printf(“t 插入成功!n”);

      }

      mysql_free_result(result);

      //釋放結(jié)果集

      }

      mysql_close(&mysql);

      //釋放連接

      }

      inquire();

      /*詢問(wèn)是否顯示主菜單*/ }

      void ModifyBook()

      /*修改圖書(shū)信息*/ {

      char id[10];

      /*結(jié)果集中的行數(shù)*/

      char *sql;

      char dest[500] ={“

      ”};

      char dest1[500] ={“

      ”};

      char *bookname;

      char *author;

      char *bookconcern;

      if(!mysql_real_connect(&mysql,“127.0.0.1”,“root”,“111”,“db_books”,0,NULL,0))

      {

      printf(“t 不能連接數(shù)據(jù)庫(kù)!n”);

      }

      else

      {

      /*數(shù)據(jù)庫(kù)連接成功*/

      // printf(“連接成功”);

      printf(“t 請(qǐng)輸入您想要修改的圖書(shū)編號(hào).”);

      scanf(“%s”,id);

      /*輸入圖書(shū)編號(hào)*/

      sql = “select * from tb_book where id=”;

      strcat(dest,sql);

      strcat(dest,id);

      /*將圖書(shū)編號(hào)追加到sql語(yǔ)句后面*/

      //printf(“%sn”,dest);

      /*查詢?cè)搱D書(shū)信息是否存在*/

      if(mysql_query(&mysql,dest))

      {

      //如果查詢失敗

      printf(“n 查詢 tb_book 數(shù)據(jù)表失敗!n”);

      }

      else

      {

      result=mysql_store_result(&mysql);//獲得結(jié)果集

      if(mysql_num_rows(result)!=NULL)

      {

      //有記錄的情況,只有有記錄取數(shù)據(jù)才有意義

      printf(“t 發(fā)現(xiàn)記錄信息,是否顯示?(y/n)”);

      scanf(“%s”,ch);

      if(strcmp(ch,“Y”)==0||strcmp(ch,“y”)==0)/*判斷是否要顯示查找到的信息*/

      {

      printf(“t ════════════════════════════

      n”);

      printf(“t

      ***** 顯示圖書(shū)信息 *****

      n”);

      printf(“t ════════════════════════════ n”);

      printf(“t圖書(shū)編號(hào)

      圖書(shū)名

      作者

      出版社

      n”);

      printf(“t-------------------------n”);

      while((row=mysql_fetch_row(result)))

      {

      //取出結(jié)果集中記錄

      fprintf(stdout,“t

      %s

      %s

      %s

      %s

      n”,row[0],row[1],row[2],row[3]);//輸出這行記錄

      }

      printf(“t ════════════════════════════ n”);

      }

      printf(“t Modify?(y/n)”);

      scanf(“%s”,ch);

      if(strcmp(ch,“Y”)==0||strcmp(ch,“y”)==0)

      /*判斷是否需要錄入*/

      {

      sql = “update tb_book set bookname= '”;

      strcat(dest1,sql);

      //

      printf(“%s”,sql);

      bookname =(char*)malloc(20);

      author =(char*)malloc(20);

      bookconcern =(char*)malloc(20);

      printf(“t 圖書(shū)名:”);

      scanf(“%s”,bookname);

      /*輸入圖書(shū)名*/

      strcat(dest1,bookname);

      // printf(“%s”,&bookname);

      printf(“t 作者:”);

      scanf(“%s”,author);

      /*輸入作者*/

      strcat(dest1,“', author= '”);

      strcat(dest1,author);

      /*追加sql語(yǔ)句*/

      printf(“t 出版社:”);

      scanf(“%s”,bookconcern);

      /*輸入出版社*/

      strcat(dest1,“', bookconcern = '”);

      strcat(dest1,bookconcern);

      /*追加sql語(yǔ)句*/

      strcat(dest1,“' where id= ”);

      strcat(dest1,id);

      //printf(“%s”,dest1);

      if(mysql_query(&mysql,dest1)!=0)

      {

      fprintf(stderr,“t 不能修改記錄!n”,mysql_error(&mysql));

      }

      else

      {

      printf(“t 修改成功!n”);

      }

      }

      }

      else

      {

      printf(“t 沒(méi)有發(fā)現(xiàn)要修改的信息!n”);

      }

      }

      mysql_free_result(result);

      //釋放結(jié)果集

      }

      mysql_close(&mysql);

      //釋放連接

      inquire();

      /*詢問(wèn)是否顯示主菜單*/ }

      void DeleteBook()

      /*刪除圖書(shū)信息*/ {

      char id[10];

      /*結(jié)果集中的行數(shù)*/

      char *sql;

      char dest[100] ={“

      ”};

      char dest1[100] ={“

      ”};

      if(!mysql_real_connect(&mysql,“127.0.0.1”,“root”,“111”,“db_books”,0,NULL,0))

      {

      printf(“t 不能連接數(shù)據(jù)庫(kù)!n”);

      }

      else

      {

      printf(“t 請(qǐng)輸入您想要?jiǎng)h除的圖書(shū)編號(hào).”);

      scanf(“%s”,id);

      /*輸入圖書(shū)編號(hào)*/

      sql = “select * from tb_book where id=”;

      strcat(dest,sql);

      strcat(dest,id);

      /*將圖書(shū)編號(hào)追加到sql語(yǔ)句后面*/

      //printf(“%sn”,dest);

      /*查詢?cè)搱D書(shū)信息是否存在*/

      if(mysql_query(&mysql,dest))

      {

      //如果查詢失敗

      printf(“n 查詢 tb_book 數(shù)據(jù)表失敗!n”);

      }

      else

      {

      result=mysql_store_result(&mysql);//獲得結(jié)果集

      if(mysql_num_rows(result)!=NULL)

      { //有記錄的情況,只有有記錄取數(shù)據(jù)才有意義

      printf(“t 發(fā)現(xiàn)記錄信息,是否顯示?(y/n)”);

      scanf(“%s”,ch);

      if(strcmp(ch,“Y”)==0||strcmp(ch,“y”)==0)/*判斷是否要顯示查找到的信息*/

      {

      printf(“t ════════════════════════════

      n”);

      printf(“t

      ***** 顯示圖書(shū)信息 *****

      n”);

      printf(“t ════════════════════════════ n”);

      printf(“t圖書(shū)編號(hào)

      圖書(shū)名

      作者

      出版社

      n”);

      printf(“t-------------------------n”);

      while((row=mysql_fetch_row(result)))

      {

      //取出結(jié)果集中記錄

      fprintf(stdout,“t

      %s

      %s

      %s

      %s

      n”,row[0],row[1],row[2],row[3]);//輸出這行記錄

      }

      printf(“t ════════════════════════════ n”);

      }

      printf(“t 是否刪除?(y/n)”);

      scanf(“%s”,ch);

      if(strcmp(ch,“Y”)==0||strcmp(ch,“y”)==0)

      /*判斷是否需要錄入*/

      {

      sql = “delete from tb_book where ID= ”;

      printf(“%s”,dest1);

      strcat(dest1,sql);

      strcat(dest1,id);

      // printf(“%s”,dest1);

      if(mysql_query(&mysql,dest1)!=0)

      {

      fprintf(stderr,“t 不能刪除記錄!n”,mysql_error(&mysql));

      }

      else

      {

      printf(“t 刪除成功!n”);

      }

      }

      }

      else

      {

      printf(“t 沒(méi)有發(fā)現(xiàn)要?jiǎng)h除的信息!n”);

      }

      }

      mysql_free_result(result);

      //釋放結(jié)果集

      }

      mysql_close(&mysql);

      inquire();

      /*詢問(wèn)是否顯示主菜單*/ }

      void QueryBook()

      /*查詢圖書(shū)信息*/ {

      char id[10];

      /*結(jié)果集中的行數(shù)*/

      char *sql;

      char dest[100] ={“

      ”};

      if(!mysql_real_connect(&mysql,“127.0.0.1”,“root”,“111”,“db_books”,0,NULL,0))

      {

      printf(“t 不能連接數(shù)據(jù)庫(kù)!n”);

      }

      else

      {

      printf(“t 請(qǐng)輸入您想要查詢的圖書(shū)編號(hào):”);

      scanf(“%s”,id);

      /*輸入圖書(shū)編號(hào)*/

      sql = “select * from tb_book where id=”;

      strcat(dest,sql);

      strcat(dest,id);

      /*將圖書(shū)編號(hào)追加到sql語(yǔ)句后面*/

      if(mysql_query(&mysql,dest))

      {

      //如果查詢失敗

      printf(“n 查詢 tb_book 數(shù)據(jù)表失敗!n”);

      }

      else

      {

      result=mysql_store_result(&mysql);//獲得結(jié)果集

      if(mysql_num_rows(result)!=NULL)

      { //有記錄的情況,只有有記錄取數(shù)據(jù)才有意義

      printf(“t ════════════════════════════

      n”);

      printf(“t

      顯示圖書(shū)信息

      n”);

      printf(“t ════════════════════════════ n”);

      printf(“t圖書(shū)編號(hào)

      圖書(shū)名

      作者

      出版社

      n”);

      printf(“t-------------------------n”);

      while((row=mysql_fetch_row(result)))

      {

      //取出結(jié)果集中記錄

      fprintf(stdout,“t

      %s

      %s

      %s

      %s

      n”,row[0],row[1],row[2],row[3]);//輸出這行記錄

      }

      printf(“t ════════════════════════════ n”);

      }

      else

      {

      printf(“t 沒(méi)有發(fā)現(xiàn)要查詢的信息!n”);

      }

      mysql_free_result(result);

      //釋放結(jié)果集

      }

      mysql_close(&mysql);

      //釋放連接

      }

      inquire();

      /*詢問(wèn)是否顯示主菜單*/ }

      說(shuō)明部分

      附加MySQL數(shù)據(jù)庫(kù)

      將工程文件夾中的data文件夾下的db_books文件夾拷貝到本地Mysql數(shù)據(jù)庫(kù)安裝文件夾的data文件夾中。即可完成對(duì)數(shù)據(jù)庫(kù)的附加。

      連接MySql的步驟

      MySQL為C語(yǔ)言提供了連接數(shù)據(jù)庫(kù)的API,要想正常使用這些API,需要做以下兩件事情:(1)包含這些API的聲明文件,即mysql.h。

      (2)讓編譯器找到這些API的可執(zhí)行程序,即DLL庫(kù)。下面介紹一下詳細(xì)的步驟: 1.

      下面解決,讓編譯器找到mysql.h的問(wèn)題。需要在編譯環(huán)境中作如下的設(shè)置: 在Visual C++ 6.0中,選擇Tools(工具)/Options(選項(xiàng))菜單項(xiàng),如下圖所示。

      選擇菜單命令

      即可打開(kāi)Options對(duì)話框,在Options對(duì)話框中選擇Directories選項(xiàng)卡,在Show directories for下拉列表框中選擇Include files選項(xiàng),在Directiories列表框中添加本地安裝MySQL的include目錄路徑。如下圖所示。默認(rèn)的路徑應(yīng)該在C:Program FilesMySQLMySQL Server 5.0include。

      添加mysql.h文件

      通過(guò)上述設(shè)置,編譯器就可以知道MySQL的API接口中有哪些函數(shù),以及函數(shù)的原型是怎樣的。在編譯時(shí),所編寫(xiě)的程序已經(jīng)能夠通過(guò)編譯(compile)這步了。

      2.引入庫(kù)函數(shù)

      經(jīng)過(guò)上一步的設(shè)置,程序已經(jīng)可以編譯通過(guò)了,但是編譯通過(guò)并不等于可以生成可執(zhí)行文件。還需要告訴編譯器這些API函數(shù)的可執(zhí)行文件在哪個(gè)DLL文件(libmysql.dll)中。

      在工程中選擇Tools/Options菜單命令,將彈出Options對(duì)話框,在該對(duì)話框中選擇Directories選項(xiàng)卡,在Show directories for下拉列表框中選擇Include files選項(xiàng)。添加本地安裝的MySQL的Lib目錄路徑。默認(rèn)的安裝路徑是C:Program FilesMySQLMySQL Server 5.0libdebug 或者C:Program

      FilesMySQLMySQL Server 5.0libopt)。設(shè)置完成的效果如下圖所示。

      引用庫(kù)

      單擊OK按鈕,關(guān)閉Options對(duì)話框。選擇Project/Settings菜單命令。如下圖所示。

      選擇Project/Settings菜單項(xiàng)

      下面添加libmysql.lib到工程中。選擇Project/Settings菜單項(xiàng),將彈出Project Settings對(duì)話框,在該對(duì)話框中選擇Link選項(xiàng)卡。在Object/library modules文本框末尾添加libmysql.lib。如下圖所示。

      添加libmysql.lib到工程中

      最好將libmysql.lib以及l(fā)ibmysql.dll文件拷貝到工程的目錄下。設(shè)置完成后就可以運(yùn)行程序了程序運(yùn)行界面如下圖所示:

      第二篇:C語(yǔ)言程序設(shè)計(jì)圖書(shū)管理系統(tǒng)

      C語(yǔ)言程序設(shè)計(jì)

      實(shí)驗(yàn)報(bào)告

      題 目: 圖書(shū)管理管理系統(tǒng) 院 系: 信息科技學(xué)院 專(zhuān) 業(yè): 姓 名: 學(xué) 號(hào):

      指導(dǎo)教師: 楊呈勇 日 期: 09-09-18 問(wèn)題定義 …………………………………………………………………………..3 2 系統(tǒng)設(shè)計(jì) ……………………………………………………………………3 2.1 總體設(shè)計(jì)………………………………………………………………………………4

      2.2 詳細(xì)設(shè)計(jì)………………………………………………………………………………4 2.2.1 借書(shū)模塊 ……… ………………………………………………… 4 2.2.2 圖書(shū)維護(hù)………………………………………………………………………… 5 ① 新增記錄 …………………………………………………………………… 5 ② 更改系統(tǒng)…………………………………………….………………… 6 ③刪除系統(tǒng) …………………………………………… 6 ④ 查找系統(tǒng)……………………………………………….………………….6 ⑤ 顯示系統(tǒng) ………………………………………………………………….7 3 系統(tǒng)實(shí)現(xiàn) ………………………………………………………………………10 3.1 編碼 ………………………………………………………………………8 3.1.1 程序預(yù)處理 ……….……………………………………………………………9 3.1.2 主函數(shù)main()……….……………………………………………………….9 4 系統(tǒng)維護(hù) ………………………………………………………………………16 5 歸納總結(jié) ………………………………………………………………………16 5.1 開(kāi)發(fā)經(jīng)驗(yàn) ………………………………………………………………………16 5.2 實(shí)訓(xùn)中遇到的問(wèn)題及解決方法 ………………………………………………16 5.3 設(shè)計(jì)中的不足之處……………………………………………………………………16 5.4 感想和心得體會(huì) ……………………………………………………………………16

      圖書(shū)管理系統(tǒng)

      本題目設(shè)計(jì)目的是訓(xùn)練學(xué)生的基本編程能力,了解管理信息系統(tǒng)的開(kāi)發(fā)流程,熟悉C語(yǔ)言的文件和單鏈表的各種基本操作。本程序中涉及結(jié)構(gòu)體、單鏈表、文件及各種語(yǔ)句的運(yùn)用如for();switch();if….else等方面的知識(shí)。通過(guò)本程序的訓(xùn)練,使學(xué)生能對(duì)C語(yǔ)言的文件操作有一個(gè)更深刻的了解,初步掌握鏈表的一些結(jié)構(gòu)及構(gòu)成。掌握利用單鏈表存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)對(duì)學(xué)生成績(jī)管理的原理,為進(jìn)一步開(kāi)發(fā)出高質(zhì)量的管理信息系統(tǒng)打下堅(jiān)實(shí)的基礎(chǔ)。

      1、問(wèn)題定義

      圖書(shū)信息包括:編號(hào)、書(shū)名、作者名、分類(lèi)號(hào)、出版單位、出版時(shí)間、庫(kù)存數(shù)量,價(jià)格等。試設(shè)計(jì)一圖書(shū)信息管理系統(tǒng),使之能提供以下功能:(1)系統(tǒng)以菜單方式工作

      (2)圖書(shū)信息錄入功能(圖書(shū)信息用文件保存)(3)圖書(shū)信息瀏覽功能(4)圖書(shū)信息查詢功能

      查詢方式:可以按書(shū)名,按作者名,按出版單位,按出版時(shí)間進(jìn)行查詢。(5)圖書(shū)信息的刪除與修改

      在問(wèn)題定義階段要考慮題目的可行性和需求分析,接下來(lái)進(jìn)入開(kāi)發(fā)階段,完成系統(tǒng)設(shè)計(jì)和系統(tǒng)實(shí)現(xiàn)的任務(wù)。

      2、系統(tǒng)設(shè)計(jì) 2.1 總體設(shè)計(jì)

      采用模塊化的程序設(shè)計(jì)方法,即將較大的任務(wù)按照一定的原則分為一個(gè)個(gè)較小的任務(wù),然后分別設(shè)計(jì)各個(gè)小任務(wù)。需要注意的是劃分出來(lái)的模塊應(yīng)該相對(duì)獨(dú)立但又相關(guān),且容易理

      解??梢杂媚K化層次結(jié)構(gòu)圖(即模塊圖)來(lái)分析其任務(wù)的劃分,一般從上到下進(jìn)行,最上面一層是主模塊,下面各層是其上一層模塊的逐步細(xì)化描述。

      圖2.1

      圖書(shū)管理系統(tǒng)功能模塊圖

      ? ? ? ? 本圖書(shū)管理系統(tǒng)要求采用單鏈表實(shí)現(xiàn),如圖2.1所示,它由如下四大功能模塊組成: 借書(shū)模塊。通過(guò)輸入讀者的編號(hào)和圖書(shū)的編號(hào),查找到要該借的書(shū),完成借書(shū)這一項(xiàng)任務(wù)

      還書(shū)模塊。通過(guò)輸入讀者的編號(hào)和圖書(shū)的編號(hào),查找到要該還的書(shū),完成還書(shū)這一項(xiàng)任務(wù)

      圖書(shū)維護(hù)模塊。完成對(duì)圖書(shū)信息的維護(hù)。在此圖書(shū)管理系統(tǒng)中,它實(shí)現(xiàn)了對(duì)圖書(shū)信息的新曾、更改、刪除、查找和顯示操作,并將追加后的數(shù)據(jù)存入源數(shù)據(jù)文件。讀者維護(hù)模塊。一是實(shí)現(xiàn)對(duì)讀者記錄的存盤(pán),即將讀者信息寫(xiě)入數(shù)據(jù)文件中;

      2.2 詳細(xì)設(shè)計(jì)

      2.2.1 借書(shū)模塊

      通過(guò)輸入讀者的信息和要借的書(shū)的編號(hào)。系統(tǒng)顯示相應(yīng)的內(nèi)容,若該文件中沒(méi)有數(shù)據(jù),系統(tǒng)會(huì)提示單鏈表為空,沒(méi)有任何讀者記錄或圖書(shū)操作,此時(shí),用戶應(yīng)選擇調(diào)用create()函數(shù),進(jìn)行讀者記錄的輸入,即完成在單鏈表1中添加記錄的操作。值得一提的是,這里的字符串和數(shù)值的輸入分別采用了函數(shù)來(lái)實(shí)現(xiàn),在函數(shù)中完成輸入數(shù)據(jù)任務(wù),并對(duì)數(shù)據(jù)進(jìn)行條件判斷,直到滿足條件為止,這樣一來(lái),大大減少了代碼的重復(fù)和冗余,符合模塊化程序設(shè)計(jì)的特點(diǎn)。

      2.2.2 還書(shū)模塊

      還書(shū)模塊主要實(shí)現(xiàn)了在單鏈表中按讀者和圖書(shū)的編號(hào)查找滿足相關(guān)條件的借書(shū)記錄。在

      用戶選擇4,調(diào)用查詢函數(shù)search()中,為指向保存了讀者信息的單鏈表的首地址的指針變量。為了遵循模塊化編程的原則,我們將在單鏈表中進(jìn)行的指針定位操作,設(shè)計(jì)一個(gè)

      int retbook(int bookid)

      {

      for(int i=0;i

      {

      if(borbook[i]==bookid)

      {

      borbook[i]=0;

      return 1;

      }

      }

      return 0;

      }

      //讀出讀者信息

      void disp()

      {

      cout << setw(5)<< no <

      for(int i=0;i

      if(borbook[i]!=0)

      cout << borbook[i] << “|”;

      cout << “]”<

      }

      };

      若沒(méi)有該記錄,則顯示無(wú)此記錄,返回到上一操作。

      2.2.3 圖書(shū)維護(hù)模塊

      此模塊主要實(shí)現(xiàn)了對(duì)圖書(shū)記錄的新增、更改、刪除、查找和顯示操作。因?yàn)閳D書(shū)記錄是以單鏈表的結(jié)構(gòu)形式存儲(chǔ)的,所以這些操作都在單鏈表中完成。下面分別介紹著4個(gè)功能模塊。

      ①新增記錄。該操作需要對(duì)單鏈表中目標(biāo)節(jié)點(diǎn)的數(shù)據(jù)域中的值進(jìn)行追加新增要輸入圖書(shū)的編號(hào)和書(shū)名,int addbook(int n,char *na)

      {

      Book *p=query(n);

      if(NULL==p)

      {

      top++;

      book[top].addbook(n,na);

      return 1;

      }

      return 0;

      }

      ②更改系統(tǒng)。該操作可以將原本錯(cuò)誤的圖書(shū)記錄更改,將之改為正確的記錄。首先輸入原來(lái)的記錄的圖書(shū)的編號(hào),在此之后輸入新的記錄的書(shū)名。

      ③刪除系統(tǒng)。該操作可以將原本記錄得圖書(shū)信息,在不用之后選擇將此刪除的一種方法,在彈出的窗口輸入原來(lái)的圖書(shū)的編號(hào),就可以將之刪除。

      ④ 查找系統(tǒng)。該操作可以幫助讀者快速找到將要借的圖書(shū),只要輸入圖書(shū)的編號(hào),如果有這本書(shū),就將顯示出。反之就會(huì)顯示不存在。Book *query(int bookid)

      {

      for(int i=0;i<=top;i++)

      if(book[i].getno()==bookid &&book[i].gettag()==0)

      {

      return &book[i];

      }

      return NULL;

      }

      ⑤顯示系統(tǒng)。該操作可以顯示出圖書(shū)現(xiàn)在的信息。cout << “輸入圖書(shū)編號(hào):”<

      cin >> bookid;

      cout << “輸入圖書(shū)書(shū)名:”<

      cin >> bname;

      addbook(bookid,bname);

      break;

      case '2':

      cout << “輸入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout << “ 該圖書(shū)不存在 ”<

      break;

      }

      cout << “輸入新的書(shū)名:”<

      cin >> bname;

      b->setname(bname);

      break;

      case '3':

      cout <<“ 讀入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout <<“ 該圖書(shū)不存在” << endl;

      break;

      }

      b->delbook();

      break;

      case '4':

      cout << “ 讀入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout <<“ 該圖書(shū)不存在”<< endl;

      break;

      }

      b->disp();

      break;

      case '5':

      disp();

      break;

      case '6':

      clear();

      break;

      default:cout<<“輸入錯(cuò)誤,請(qǐng)從新輸入:”;

      }

      }

      }cout << “輸入圖書(shū)編號(hào):”<

      cin >> bookid;

      cout << “輸入圖書(shū)書(shū)名:”<

      cin >> bname;

      addbook(bookid,bname);

      break;

      case '2':

      cout << “輸入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout << “ 該圖書(shū)不存在 ”<

      break;

      }

      cout << “輸入新的書(shū)名:”<

      cin >> bname;

      b->setname(bname);

      break;

      case '3':

      cout <<“ 讀入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout <<“ 該圖書(shū)不存在” << endl;

      break;

      }

      b->delbook();

      break;

      case '4':

      cout << “ 讀入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout <<“ 該圖書(shū)不存在”<< endl;

      break;

      }

      b->disp();

      break;

      case '5':

      disp();

      break;

      case '6':

      clear();

      break;

      default:cout<<“輸入錯(cuò)誤,請(qǐng)從新輸入:”;

      }

      }

      } cout << “輸入圖書(shū)編號(hào):”<

      cin >> bookid;

      cout << “輸入圖書(shū)書(shū)名:”<

      cin >> bname;

      addbook(bookid,bname);

      break;

      case '2':

      cout << “輸入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout << “ 該圖書(shū)不存在 ”<

      break;

      }

      cout << “輸入新的書(shū)名:”<

      cin >> bname;

      b->setname(bname);

      break;

      case '3':

      cout <<“ 讀入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout <<“ 該圖書(shū)不存在” << endl;

      break;

      }

      b->delbook();

      break;

      case '4':

      cout << “ 讀入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout <<“ 該圖書(shū)不存在”<< endl;

      break;

      }

      b->disp();

      break;

      case '5':

      disp();

      break;

      case '6':

      clear();

      break;

      default:cout<<“輸入錯(cuò)誤,請(qǐng)從新輸入:”;

      }

      }

      3、系統(tǒng)實(shí)現(xiàn) 3.1 編碼

      3.1.2 主函數(shù)main()include

      #include

      #include

      //輸入/輸出文件流類(lèi)

      #include

      using namespace std;

      //最多的讀者

      const int Maxr=100;

      //最多的圖書(shū)

      const int Maxb=100;

      //每位讀者最多借五本書(shū)

      const int Maxbor=5;

      //圖書(shū)庫(kù)類(lèi),實(shí)現(xiàn)對(duì)圖書(shū)的維護(hù),查找,刪除等

      class BDatabase

      {

      private:

      //圖書(shū)記錄指針

      int top;

      //圖書(shū)記錄

      Book book[Maxb];

      public:

      //構(gòu)造函數(shù),將book.txt讀到book[]中

      BDatabase()

      {

      Book b;

      top=-1;

      fstream file(“book.txt”,ios::in);

      while(1)

      {

      file.read((char *)&b,sizeof(b));

      if(!file)break;

      top++;

      book[top]=b;

      }

      file.close();

      }

      //全刪

      void clear()

      {

      top=-1;

      }

      //增加圖書(shū)

      int addbook(int n,char *na)

      {

      Book *p=query(n);

      if(NULL==p)

      {

      top++;

      book[top].addbook(n,na);

      return 1;

      }

      return 0;

      }

      //查找圖書(shū)

      Book *query(int bookid)

      {

      for(int i=0;i<=top;i++)

      if(book[i].getno()==bookid &&book[i].gettag()==0)

      {

      return &book[i];

      }

      return NULL;

      }

      //圖書(shū)庫(kù)維護(hù)

      void bookdata();

      void disp()

      {

      for(int i=0;i<=top;i++)

      if(book[i].gettag()==0)

      book[i].disp();

      }

      //析構(gòu)函數(shù),將book[]寫(xiě)到book.txt文件中

      ~BDatabase()

      {

      fstream file(“book.txt”,ios::out);

      for(int i=0;i<=top;i++)

      if(book[i].gettag()==0)

      file.write((char *)&book[i],sizeof(book[i]));

      file.close();

      }

      };

      void BDatabase::bookdata()

      {

      char choice;

      char bname[40];

      int bookid;

      Book *b;

      while(choice!='0')

      {

      cout <<“nnnttt圖 書(shū) 維 護(hù) ”<

      cout<<“tt1 新 增n tt2 更 改ntt3 刪 除ntt4 查 找ntt5 顯 示ntt6 全 刪ntt0 退 出”<

      cin >> choice;

      switch(choice)

      {

      case '1':

      cout << “輸入圖書(shū)編號(hào):”<

      cin >> bookid;

      cout << “輸入圖書(shū)書(shū)名:”<

      cin >> bname;

      addbook(bookid,bname);

      break;

      case '2':

      cout << “輸入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout << “ 該圖書(shū)不存在 ”<

      break;

      }

      cout << “輸入新的書(shū)名:”<

      cin >> bname;

      b->setname(bname);

      break;

      case '3':

      cout <<“ 讀入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout <<“ 該圖書(shū)不存在” << endl;

      break;

      }

      b->delbook();

      break;

      case '4':

      cout << “ 讀入圖書(shū)編號(hào):”<

      cin >> bookid;

      b=query(bookid);

      if(b==NULL)

      {

      cout <<“ 該圖書(shū)不存在”<< endl;

      break;

      }

      b->disp();

      break;

      case '5':

      disp();

      break;

      case '6':

      clear();

      break;

      default:cout<<“輸入錯(cuò)誤,請(qǐng)從新輸入:”;

      }

      }

      }

      //main()函數(shù)的實(shí)現(xiàn),程序的主界面的引導(dǎo)

      int main()

      {

      char choice;

      int bookid,readerid;

      RDatabase ReaderDB;

      Reader *r;

      BDatabase BookDB;

      Book *b;

      while(choice!='0')

      {

      cout <

      cout <<“ttt1 借 書(shū)nnttt2 還 書(shū) nnttt3 圖 書(shū) 維 護(hù)nnttt4 讀 者 維 護(hù)nnttt0 離 開(kāi)”<

      cin >> choice;

      switch(choice)

      {

      case '1':

      cout <<“ 借書(shū) 讀者編號(hào):”;

      cin >>readerid;

      cout <<“ 圖書(shū)編號(hào): ”;

      cin >>bookid;

      //按編號(hào)查找

      r=ReaderDB.query(readerid);

      if(NULL==r)

      {

      cout <<“ 不存在該讀者,不能借書(shū)”<< endl;

      break;

      }

      b=BookDB.query(bookid);

      if(b==NULL)

      {

      cout <<“ 不存在該圖書(shū),不能借書(shū)”<< endl;

      break;

      }

      if(b->borrowbook()==0)

      {

      cout << “ 該圖書(shū)已借出,不能借書(shū)”<< endl;

      break;

      }

      r->borrowbook(b->getno());

      break;

      case '2':

      cout<<“還書(shū)n 讀者編號(hào):”;

      cin >>readerid;

      cout << “ 圖書(shū)編號(hào):”;

      cin >>bookid;

      r=ReaderDB.query(readerid);

      if(r==NULL)

      {

      cout <<“ 不存在該讀者,不能還書(shū)” << endl;

      break;

      }

      b=BookDB.query(bookid);

      if(b==NULL)

      {

      cout <<“ 不存在該圖書(shū),不能還書(shū)” <

      break;

      }

      b->retbook();

      r->retbook(b->getno());

      break;

      case '3':

      BookDB.bookdata();

      break;

      case '4':

      ReaderDB.readerdata();

      break;

      default:cout<<“輸入錯(cuò)誤,請(qǐng)從新輸入:”;

      4、系統(tǒng)維護(hù)

      經(jīng)測(cè)試與調(diào)試確認(rèn)軟件無(wú)錯(cuò)時(shí),開(kāi)發(fā)就告一段落,這時(shí)可以交付軟件供用戶使用,但是在軟件的使用過(guò)程中還會(huì)面臨更加漫長(zhǎng)的工作,即軟件維護(hù)。一般維護(hù)的工作有:更改使用中發(fā)現(xiàn)的錯(cuò)誤;為適應(yīng)實(shí)際環(huán)境而對(duì)程序進(jìn)行修改;為滿足新的需求而對(duì)程序作必要的改進(jìn)等等。

      5、歸納總結(jié) 5.1 開(kāi)發(fā)經(jīng)驗(yàn)

      通過(guò)對(duì)本題目的開(kāi)發(fā),體會(huì)到要掌握以下幾點(diǎn)內(nèi)容。

      ? 大程序的設(shè)計(jì)風(fēng)格。按“自頂向下,逐步細(xì)化,模塊化”的方法進(jìn)行程序設(shè)計(jì)。? 編寫(xiě)主函數(shù),并進(jìn)行測(cè)試與調(diào)試。當(dāng)被調(diào)函數(shù)又需要調(diào)用其他函數(shù)時(shí),也要遵循逐步細(xì)化的原則。C語(yǔ)言提供豐富的庫(kù)函數(shù),編程序時(shí)要善于使用庫(kù)函數(shù),避免不必要的勞動(dòng)。? 定義函數(shù)時(shí),應(yīng)選好參數(shù)的個(gè)數(shù)和數(shù)據(jù)類(lèi)型。? 文件使用方法。文件使用完畢后應(yīng)及時(shí)關(guān)閉。

      5.2 實(shí)訓(xùn)中遇到的問(wèn)題及解決方法

      在實(shí)訓(xùn)過(guò)程中,我遇到許多的問(wèn)題,比如有些語(yǔ)句有語(yǔ)法錯(cuò)誤,表達(dá)式不正確,或缺少}或;等?;蛘呤菦](méi)有宏定義,申明某些變量。這些都比較容易解決。通過(guò)查閱課本和請(qǐng)教同學(xué),在經(jīng)過(guò)WIN-TV編譯,知道哪有錯(cuò)誤就改一下就行。比較嚴(yán)重的是,我的代碼在求解平均成績(jī)和總分時(shí)沒(méi)有錄入,且亂碼。自已改了很久,也在網(wǎng)上查詢但是都不行。最后在老師的幫助下及查閱有關(guān)資料,把代碼改出來(lái)了。

      5.3 設(shè)計(jì)中尚存的不足之處

      關(guān)于這次的程序,也有挺多不足的地方。首先,我覺(jué)得程序還不夠完善,比如沒(méi)有排序前和排序后的學(xué)生記錄輸出結(jié)果顯示和有些程序功能沒(méi)有滿足所給題目要求及好幾項(xiàng)都沒(méi)有顯示出學(xué)生具體的信息,甚至有些地方有點(diǎn)亂;其次,有些地方好像功能有點(diǎn)重復(fù)了,且編寫(xiě)的代碼有重復(fù);最后,就是該程序界面不夠美觀大方,有些文件不能鏈接。

      5.4 感想和心得體會(huì)

      通過(guò)這次實(shí)訓(xùn),我感觸甚深,要把所學(xué)的理論知識(shí)運(yùn)用于解決實(shí)際問(wèn)題不僅要付出艱辛的勞動(dòng),還得要有科學(xué)的方法和堅(jiān)持不懈的努力。加上我們只是學(xué)了一個(gè)學(xué)期的c語(yǔ)言,我們所學(xué)的知識(shí)還不足以獨(dú)立編寫(xiě)程序代碼。但是我認(rèn)為只要我們認(rèn)真的去學(xué)去做,我們會(huì)受益非淺。這次實(shí)訓(xùn)讓我進(jìn)一步理解了“編程是什么”,“如何去編程”,“編程的目的又是什么”,??發(fā)現(xiàn)自己的知識(shí)竟是如此貧乏,頓時(shí)感到了壓力的存在,從而也激發(fā)了我的學(xué)習(xí)熱情。它會(huì)成為我今后不斷進(jìn)取、永不懈怠的動(dòng)力。

      在整個(gè)實(shí)訓(xùn)過(guò)程中,老師給了我很大的幫助,使我由不了解怎樣運(yùn)用鏈表到逐漸懂得鏈表的結(jié)構(gòu)及初步掌握鏈表結(jié)構(gòu)。還重新復(fù)習(xí)了一些語(yǔ)句的使用,比如for(0;switch();if….elser();結(jié)構(gòu)體的使用;枚舉等。而且我能夠堅(jiān)持虛心的向老師以及同學(xué)請(qǐng)教問(wèn)題。它使我明白了虛心好學(xué)的重要性,更讓我懂得了如何跟老師同學(xué)去相處、去溝通。沒(méi)有老師和同學(xué)們的無(wú)私幫助,我不可能圓滿完成這次實(shí)訓(xùn)任務(wù)。非常感謝幫助過(guò)我的所有老師和同學(xué)們,在此,謹(jǐn)向他們一并表示感謝!我開(kāi)始喜歡這個(gè)程序設(shè)計(jì)了,尤其覺(jué)得它是很有挑戰(zhàn)性的,是對(duì)知識(shí)點(diǎn)扎實(shí)程度的考察,也是對(duì)個(gè)人能力的考察,還是對(duì)個(gè)人化毅力的考驗(yàn)。它讓我明白做任何事都不應(yīng)該輕易放棄。這樣的課程設(shè)計(jì),既有利于教學(xué),又可以教會(huì)學(xué)生書(shū)本以外的很多知識(shí)?,F(xiàn)在我對(duì)它越來(lái)越感興趣,今后我會(huì)更加關(guān)注C語(yǔ)言程序,把C語(yǔ)言學(xué)好。希望老師以后多多指導(dǎo),給予一定的幫助!

      第三篇:圖書(shū)管理系統(tǒng)

      圖書(shū)管理系統(tǒng)源代碼

      #include #include class Book{ // 書(shū)籍基類(lèi) protected: char Title[40];// 書(shū)名 long Code;// 條碼 int Type;// 0表示書(shū),1表示雜志 public: Book();Book(char *title,long code);void SetCode(long code){ Code = code;} void SetTitle(char* tl){ strcpy(Title,tl);} void SetType(bool type){Type = type;} int GetType(){ return Type;} long GetCode(){ return Code;} virtual void Show();// 顯示書(shū)的信息 friend ostream& operator<<(ostream& , Book&);// 重載插入運(yùn)算符 friend istream& operator>>(istream& is, Book&);// 重載提取運(yùn)算符 Book *Next;// 為創(chuàng)建每個(gè)讀者所借書(shū)鏈表而定義指針 };class Item :public Book{ //書(shū)的款目 // char Title[40];// 書(shū)名 char Author[20];// 著者名 char IndexCode[10];// 分類(lèi)號(hào) // long Code;// 條碼 public: Item();Item(char *author,char *title,char *index,int code);Item(Item &);void SetAuthor(char*);void SetIndexCode(char*);virtual void Show();// 顯示書(shū)的信息 friend ostream& operator<<(ostream& os, Item&);// 重載插入運(yùn)算符 friend istream& operator>>(istream& is, Item&);// 重載提取運(yùn)算符 public: };class Magazine:public Book { //雜志類(lèi) int Volume;enum LANG {CHINESE=1,ENGLISH} Lang;// 枚舉變量,確定語(yǔ)言類(lèi)別 public: Magazine():Book(){Volume = 0;Lang = CHINESE;Type = 1;} Magazine(char *title,int vol,LANG lang,int code);Magazine(Magazine&);void SetVolume(int vol){Volume = vol;} void SetLang(int lang){Lang =(LANG)lang;} virtual void Show();// 顯示雜志的信息 friend ostream& operator<<(ostream& os, Magazine&);// 重載插入運(yùn)算符 friend istream& operator>>(istream& is, Magazine&);// 重載提取運(yùn)算符 };class Reader{ // 讀者信息類(lèi) char Name[20];// 姓名 char Position[20];// 職務(wù) int Age;// 年齡 long Code;// 借書(shū)證號(hào) Book* items;// 所借書(shū)鏈表 public: Reader();Reader(char *name,char *posi,int age,int code);// Reader(Reader&);~Reader();long GetCode(){return Code;} void SetName(char*);void SetPosition(char*);void SetAge(int);void SetCode(long);void AddBook(Item);// 添加所借書(shū) void AddBook(Magazine);// 添加所借雜志 void DelBook(Book it);// 還書(shū)后減少所借書(shū) void ShowBooks();// 顯示所借書(shū) void Show();// 顯示讀者信息 friend ostream& operator<<(ostream& os, Reader&);// 重載插入運(yùn)算符 friend istream& operator>>(istream& is, Reader&);// 重載提取運(yùn)算符 public: int Counter;//計(jì)數(shù)器,統(tǒng)計(jì)所借書(shū)數(shù)目 };class Manager{ // 管理員類(lèi) char Name[20];// 姓名 int Age;// 年齡 int Code;// 工號(hào) friend class Library;// 將圖書(shū)館類(lèi)聲明為友元 public: Manager(){} Manager(char*,int,int);long GetCode(){ return Code;} void Show();friend ostream& operator<<(ostream& os, Manager&);// 重載插入運(yùn)算符 friend istream& operator>>(istream& is, Manager&);// 重載提取運(yùn)算符 };class Loan { // 借閱信息類(lèi) int Type;// 0表示書(shū),1表示雜志 Item item;// 借閱書(shū) Magazine mag;// 借閱雜志 Reader reader;// 借閱者 Manager manager;// 借書(shū)操作員 int Code;friend class Library;// 將圖書(shū)館類(lèi)聲明為友元 public: Loan(){ } Loan(Loan & l);int GetCode(){ return Code;} void Show();friend ostream& operator<<(ostream& os, Loan&);// 重載插入運(yùn)算符 friend istream& operator>>(istream& is, Loan&);// 重載提取運(yùn)算符 };、、、、、、、、、、、、、、、、、、、、、、、#include #include class Reader;template class DblList;template class DblNode{ public: T Info;//數(shù)據(jù)域 DblNode *llink,*rlink;//前驅(qū)(左鏈)、后繼(右鏈)指針 public: DblNode(T data);//一般結(jié)點(diǎn) DblNode();//頭結(jié)點(diǎn) T GetInfo(){return Info;};friend class DblList;friend class Library;};templateclass DblList{ DblNode *head,*current;public: DblList();~DblList();void Insert(const T& data);DblNode* Remove(DblNode* p);void Print();int

      Length();//計(jì)算鏈表長(zhǎng)度 DblNode *Find(T data);//搜索數(shù)據(jù)與定值相同的結(jié)點(diǎn) DblNode* Find(int data);//按某個(gè)關(guān)鍵字查找 void MakeEmpty();//清空鏈表 void ShowList();//顯示鏈表各結(jié)點(diǎn) friend istream& operator>>(istream&, DblList&);// 重載輸入流運(yùn)算符 friend ostream& operator<<(ostream& os, DblList& dlist);// 重載輸出流運(yùn)算符 friend class Library;//其它操作 };template DblNode::DblNode(){ llink=rlink=NULL;} template DblNode::DblNode(T data){ info=data;llink=NULL;rlink=NULL;} template DblList::DblList(){//建立表頭結(jié)點(diǎn) head=new DblNode();head->rlink=head->llink=head;current=NULL;} template DblList::~DblList(){ MakeEmpty();//清空鏈表 delete head;} template void DblList::MakeEmpty(){ DblNode *tempP;while(head->rlink!=head){ tempP=head->rlink;head->rlink=tempP->rlink;//把頭結(jié)點(diǎn)后的第一個(gè)節(jié)點(diǎn)從鏈中脫離 tempP->rlink->llink=head;//處理左指針 delete tempP;//刪除(釋放)脫離下來(lái)的結(jié)點(diǎn) } current=NULL;//current指針恢復(fù) } template void DblList::Insert(const T & data){//新節(jié)點(diǎn)在鏈尾 current=new DblNode;current->Info=data;current->rlink=head;//注意次序 current->llink=head->llink;head->llink->rlink=current;head->llink=current;//最后做 } template DblNode* DblList::Remove(DblNode* p){ // 刪除結(jié)點(diǎn) current=head->rlink;while(current!=head&¤t!=p)current=current->rlink;if(current==head)current=NULL;else{//結(jié)點(diǎn)摘下 p->llink->rlink=p->rlink;p->rlink->llink=p->llink;p->rlink=p->llink=NULL;} return current;} template DblNode* DblList::Find(T data){ // 按結(jié)點(diǎn)查找 current=head->rlink;while(current!=head&¤t->Info!=data)current=current->rlink;if(current==head)current=NULL;return current;} template DblNode* DblList::Find(int data){ // 按數(shù)據(jù)值查找結(jié)點(diǎn) current=head->rlink;int temp =current->Info.GetCode();while(current!=head&&temp!=data){ current=current->rlink;temp = current->Info.GetCode();} if(current==head)current=NULL;return current;} template void DblList::Print(){ // 輸出鏈表 current=head->rlink;while(current!=head){ cout<Info<<'t';current=current->rlink;} cout< int DblList::Length(){ // 取得鏈表長(zhǎng)度 int count=0;current=head->rlink;while(current!=head){ count++;current=current->rlink;} return count;} template void DblList::ShowList(){ // 輸出鏈表各結(jié)點(diǎn) int count=0;current=head->rlink;while(current!=head){ current->GetInfo().Show();current=current->rlink;} return;} template istream& operator>>(istream& is, DblList &dlist){ int len;T tt;// 定義局部變量讀入一個(gè)結(jié)點(diǎn) is>>len;for(int i= 0;i>tt;dlist.Insert(tt);} return is;} template ostream& operator<<(ostream& os, DblList &dlist){ DblNode *tempP;int len = dlist.Length();os<rlink;while(tempP!=dlist.head){ // 循環(huán)輸出鏈表各結(jié)點(diǎn) os<Info;tempP = tempP->rlink;} return os;} #include “class.h” #include “dblist.h” #include class Library{ // 封裝圖書(shū)館流通業(yè)務(wù)的類(lèi) DblList item;// 在館圖書(shū)鏈表 DblList mag;// 在館雜志鏈表 DblList reader;// 讀者鏈表 DblList loan;// 借閱信息鏈表 DblList manager;// 管理員信息鏈表 int itemNum;// 記錄在館圖書(shū)數(shù)目 int magNum;// 記錄在館雜志數(shù)目 int readerNum;// 記錄讀者數(shù)目 int loanNum;// 記錄借閱信息數(shù)目 int managerNum;// 記錄管理員數(shù)目 ofstream itemFileOut;// 文件流對(duì)象,保存圖書(shū)館書(shū)籍?dāng)?shù)據(jù) ifstream itemFileIn;// 文件流對(duì)

      象,讀入圖書(shū)館書(shū)籍?dāng)?shù)據(jù) ofstream magFileOut;// 文件流對(duì)象,保存圖書(shū)館雜志數(shù)據(jù) ifstream magFileIn;// 文件流對(duì)象,讀入圖書(shū)館雜志數(shù)據(jù) ofstream readerFileOut;// 文件流對(duì)象,保存圖書(shū)館讀者數(shù)據(jù) ifstream readerFileIn;// 文件流對(duì)象,讀入圖書(shū)館讀者數(shù)據(jù) ofstream loanFileOut;// 文件流對(duì)象,保存圖書(shū)館借閱信息數(shù)據(jù) ifstream loanFileIn;// 文件流對(duì)象,讀入圖書(shū)館借閱信息 ofstream managerFileOut;// 文件流對(duì)象,保存圖書(shū)館管理員數(shù)據(jù) ifstream managerFileIn;// 文件流對(duì)象,讀入圖書(shū)館管理員數(shù)據(jù) public: Library();// 構(gòu)造函數(shù) ~Library();//析構(gòu)函數(shù) void Run();// 圖書(shū)館類(lèi)的運(yùn)行函數(shù) void CreateBibliotheca();// 創(chuàng)建書(shū)目 void CreateReader();// 創(chuàng)建讀者庫(kù) void CreateManager();// 創(chuàng)建管理員信息 int ShowMainMenu();// 顯示主菜單函數(shù) void Borrow();// 借書(shū)操作 void Return();// 還書(shū)操作 void Require();// 查詢操作 void SaveInfo();// 保存圖書(shū)館信息 void OpenInfo();// 讀入圖書(shū)館信息 };

      第四篇:圖書(shū)管理系統(tǒng)

      目錄

      第一章 緒論.....................................................................................................................................1 第二章 需求分析..............................................................................................................................2

      2.1任務(wù)概述............................................................................................................................2

      2.1.1 圖書(shū)管理系統(tǒng)完成的主要目標(biāo)...........................................................................2 2.1.2用戶的特點(diǎn)............................................................................................................3 2.2需求規(guī)定............................................................................................................................3

      2.2.1對(duì)功能的規(guī)定........................................................................................................3 2.2.2讀者管理功能........................................................................................................4 2.2.3系統(tǒng)管理功能........................................................................................................4

      第三章 概要設(shè)計(jì).............................................................................................................................4

      3.1總體設(shè)計(jì)............................................................................................................................4

      3.1.1系統(tǒng)目標(biāo)設(shè)計(jì)........................................................................................................4 3.1.2系統(tǒng)功能分析........................................................................................................5 3.2系統(tǒng)設(shè)計(jì)思想.....................................................................................................................5 3.3 系統(tǒng)模塊功能解析............................................................................................................5 第四章 詳細(xì)設(shè)計(jì).............................................................................................................................6

      4.1程序設(shè)計(jì)說(shuō)明....................................................................................................................6

      4.1.1用戶登錄模塊........................................................................................................6 4.1.2用戶添加模塊........................................................................................................7 4.1.3書(shū)籍查詢模塊........................................................................................................8 4.1.4圖書(shū)借閱模塊........................................................................................................9 4.1.5圖書(shū)歸還模塊......................................................................................................10 4.1.6新書(shū)入庫(kù)模塊......................................................................................................11 第五章 編碼與測(cè)試.......................................................................................................................13 5.1各功能模塊的實(shí)現(xiàn)...........................................................................................................13 5.2 測(cè)試.................................................................................................................................19 5.2.1借閱卡管理測(cè)試..................................................................................................19 5.2.2書(shū)籍管理測(cè)試......................................................................................................19 5.2.3系統(tǒng)管理測(cè)試......................................................................................................19 結(jié)束語(yǔ).............................................................................................................................................20 致

      謝...........................................................................................................................................21 參考文獻(xiàn).........................................................................................................................................21

      圖書(shū)管理系統(tǒng)

      摘要:本文介紹了在VB6.0環(huán)境下采用“自上而下地總體規(guī)劃,自下而上地應(yīng)用開(kāi)發(fā)”的策略開(kāi)發(fā)一個(gè)管理信息系統(tǒng)的過(guò)程。通過(guò)分析傳統(tǒng)的人工管理圖書(shū)館的不足,創(chuàng)建了一套行之有效的計(jì)算機(jī)管理圖書(shū)館的方案。文章詳細(xì)介紹了圖書(shū)管理信息系統(tǒng)的系統(tǒng)分析部分,包括可行性分析、組織機(jī)構(gòu)分析、管理職能分析、業(yè)務(wù)流程分析、數(shù)據(jù)流程分析、數(shù)據(jù)字典、處理描述等等;系統(tǒng)設(shè)計(jì)部分主要介紹了系統(tǒng)功能設(shè)計(jì)和數(shù)據(jù)庫(kù)設(shè)計(jì);系統(tǒng)實(shí)現(xiàn)部分列出了幾個(gè)主要的程序框圖,并附帶了一些主要的窗口和程序。關(guān)鍵字:圖書(shū)管理系統(tǒng),VB6.0,sqlserver2000,信息系統(tǒng)

      Library Management System Abstract:This article introduces the detailed process of exploring a management information system under the environment of VB6.0, utilizing “Top-Bottom” overall plan and a strategy according to “Bottom-Top” application and exploitation.That is to establish a set of effective scheme for library management by computer, through analyzing disadvantages of traditional library management by human resources.This article emphasizes on three sections.The system analysis section of library management information includes feasible analysis, organizing organs analysis, management function analysis, technological process of business analysis, technological process of data analysis, data dictionary, disposal description and the like.The system design section mainly focuses on system function design and data base design.And the system realization section has provided several major program charts, together with the main windows and programs.Key words: library management system, VB6.0,information system

      第一章 緒論

      隨著人類(lèi)社會(huì)的發(fā)展,人類(lèi)對(duì)知識(shí)的需求也不斷地增長(zhǎng)。在這種形勢(shì)下,書(shū)籍就漸漸地成為人們獲取并增長(zhǎng)知識(shí)的主要途徑,而圖書(shū)館就自然而然地在人們的生活中占據(jù)了一定的位置,如何科學(xué)地管理圖書(shū)館不但關(guān)系到讀者求知的方便程度,也關(guān)系到圖書(shū)館的發(fā)展,因此,開(kāi)發(fā)一套完善的圖書(shū)館管理系統(tǒng)就必不可

      少了。

      圖書(shū)館管理系統(tǒng)是典型的信息管理系統(tǒng),其開(kāi)發(fā)主要包括后臺(tái)數(shù)據(jù)庫(kù)的建立和維護(hù)以及前端的應(yīng)用程序的開(kāi)發(fā)兩個(gè)方面。對(duì)于前者要求建立數(shù)據(jù)的一致性和完整性,對(duì)于后者則要求應(yīng)用程序功能的完備,易用等的特點(diǎn)?;谏鲜隹紤]本系統(tǒng)主要利用VB6.0作前端的應(yīng)用開(kāi)發(fā)工具,利用sqlsever 作為后臺(tái)的數(shù)據(jù)庫(kù),利用WINDOWS作為系統(tǒng)平臺(tái)開(kāi)發(fā)的圖書(shū)管理系統(tǒng)。另外本圖書(shū)館管理系統(tǒng)利用軟件工程化思想和方法,總體上是采用結(jié)構(gòu)化生命法進(jìn)行系統(tǒng)分析和設(shè)計(jì)的,而系統(tǒng)實(shí)現(xiàn)等步驟則采用了原型法和面對(duì)對(duì)象的方法

      系統(tǒng)開(kāi)發(fā)的總目標(biāo)是實(shí)現(xiàn)內(nèi)部圖書(shū)借閱管理的系統(tǒng)化、規(guī)范化和自動(dòng)化。能夠?qū)D書(shū)進(jìn)行注冊(cè)登記,也就是將圖書(shū)的基本信息(如:書(shū)名、作者、價(jià)格等)預(yù)先存入數(shù)據(jù)庫(kù)中,供以后檢索。能夠?qū)栝喨诉M(jìn)行注冊(cè)登記,包括記錄借閱人的姓名、地址、電話等信息。提供方便的查詢方法。如:以書(shū)名、作者、出版社、出版時(shí)間(確切的時(shí)間、時(shí)間段、某一時(shí)間之前、某一時(shí)間之后)等信息進(jìn)行圖書(shū)檢索,并能反映出圖書(shū)的借閱情況;以借閱人編號(hào)對(duì)借閱人信息進(jìn)行檢索;以出版社名稱(chēng)查詢出版社聯(lián)系方式信息。提供統(tǒng)計(jì)分析功能??梢哉宫F(xiàn)出圖書(shū)類(lèi)型比例、庫(kù)存與借出比例。提供舊書(shū)銷(xiāo)毀功能,對(duì)于淘汰、損壞、丟失的書(shū)目可及時(shí)對(duì)數(shù)據(jù)庫(kù)進(jìn)行修改。能夠?qū)κ褂迷摴芾硐到y(tǒng)的用戶進(jìn)行管理,按照不同的工作職能提供不同的功能授權(quán)。提供較為完善的差錯(cuò)控制與友好的用戶界面,盡量避免誤操作。圖書(shū)館的基本功能就是為讀者提供借閱服務(wù),讀者通過(guò)借閱這一過(guò)程,可以把圖書(shū)帶出圖書(shū)館,從而使讀者能夠更方便的瀏覽圖書(shū)。借書(shū)過(guò)程中,圖書(shū)管理員要對(duì)讀者的借書(shū)資格進(jìn)行審查,對(duì)符合借書(shū)條件的讀者,允許其借書(shū),對(duì)其借書(shū)記錄進(jìn)行登記;對(duì)沒(méi)有借書(shū)資格的讀者,禁止其借書(shū)。

      在VB6.0環(huán)境下采用“自上而下地總體規(guī)劃,自下而上地應(yīng)用開(kāi)發(fā)”的策略開(kāi)發(fā)一個(gè)管理信息系統(tǒng)的過(guò)程。通過(guò)分析傳統(tǒng)的人工管理圖書(shū)館的不足,創(chuàng)建了一套行之有效的計(jì)算機(jī)管理圖書(shū)館的方案。文章詳細(xì)介紹了圖書(shū)管理信息系統(tǒng)的系統(tǒng)分析部分,包括可行性分析、組織機(jī)構(gòu)分析、管理職能分析、業(yè)務(wù)流程分析、數(shù)據(jù)流程分析、數(shù)據(jù)字典、處理描述等等;系統(tǒng)設(shè)計(jì)部分主要介紹了系統(tǒng)功能設(shè)計(jì)和數(shù)據(jù)庫(kù)設(shè)計(jì);系統(tǒng)實(shí)現(xiàn)部分列出了幾個(gè)主要的程序框圖,并附帶了一些主要的窗口和程序。

      第二章 需求分析

      2.1任務(wù)概述

      2.1.1 圖書(shū)管理系統(tǒng)完成的主要目標(biāo)

      進(jìn)入系統(tǒng)前需要身份認(rèn)證、用戶名、密碼、輸入正確方可進(jìn)入。用戶可以根據(jù)需要進(jìn)行書(shū)庫(kù)管理。用戶可以進(jìn)行借書(shū)證的辦理、查詢、掛失等操作。用戶可

      以添加賬戶和修改密碼。2.1.2用戶的特點(diǎn)

      最終用戶包括讀者(具有借閱卡的人)、圖書(shū)管理員,鑒于此軟件應(yīng)用于大學(xué)圖書(shū)管理,讀者基本都是在校大學(xué)生即校職工和領(lǐng)導(dǎo),圖書(shū)管理員都是接受過(guò)高等教育的職工,因此他們都懂得運(yùn)用基本的計(jì)算機(jī)知識(shí)。大學(xué)圖書(shū)管理系統(tǒng)的使用頻度很高,假如一個(gè)一萬(wàn)人的大學(xué)來(lái)講,每天圖書(shū)館的平均日流量為1.5萬(wàn)。因此,該軟件的可靠性、可用性、可維護(hù)性顯得尤為重要。

      2.2需求規(guī)定

      2.2.1對(duì)功能的規(guī)定

      1、圖書(shū)信息查詢/借書(shū)信息查詢:圖書(shū)館主要向讀者提供圖書(shū)借閱的服務(wù)。讀者為了借閱圖書(shū),一般情況下,需要在借書(shū)之前查詢所要借閱的圖書(shū)情況,所以圖書(shū)館需要為讀者提供圖書(shū)查詢功能。例如,讀者可能想借閱某方面的書(shū),但不知道圖書(shū)館在該方面有哪些圖書(shū)可供借閱,所以需要對(duì)圖書(shū)館的圖書(shū)進(jìn)行查詢;或者,讀者知道想借閱的圖書(shū)信息,但不知道該圖書(shū)館是否有該書(shū)或不知道圖書(shū)在圖書(shū)館的位置、是否被借出、是否可以借閱等信息,這也需要使用圖書(shū)查詢功能。一般的圖書(shū)查詢中,讀者是通過(guò)圖書(shū)登記卡、瀏覽圖書(shū)登記卡中的信息得到圖書(shū)信息的。經(jīng)過(guò)圖書(shū)查詢,讀者獲得圖書(shū)館是否有自己想要的圖書(shū),該圖書(shū)的簡(jiǎn)單信息以及圖書(shū)在圖書(shū)館的借閱位置等信息。

      2、新書(shū)入庫(kù):為了能正常運(yùn)行,圖書(shū)館要及時(shí)更新館藏圖書(shū)。對(duì)于新書(shū),要購(gòu)進(jìn),供讀者借閱;所以要設(shè)計(jì)到圖書(shū)的批量入庫(kù)。對(duì)于批量入庫(kù),圖書(shū)管理員要批量登記圖書(shū)的信息,包括書(shū)名ID、ISBN、圖書(shū)名稱(chēng)、作者、出版社、單價(jià)、入庫(kù)時(shí)間、圖書(shū)總量、現(xiàn)存總量等。

      3、借閱圖書(shū)/歸還圖書(shū):圖書(shū)館的基本功能之一就是為讀者提供借閱服務(wù),讀者通過(guò)借閱這一過(guò)程,可以把圖書(shū)帶出圖書(shū)館,從而使讀者能夠更方便的瀏覽圖書(shū)。借書(shū)過(guò)程中,圖書(shū)管理員要對(duì)讀者的借書(shū)資格進(jìn)行審查,對(duì)符合借書(shū)條件的讀者,允許其借書(shū),對(duì)其借書(shū)記錄進(jìn)行登記;對(duì)沒(méi)有借書(shū)資格的讀者,禁止其借書(shū)。具體的步驟如下:讀者向圖書(shū)管理員提交請(qǐng)求和圖書(shū)借閱卡,圖書(shū)管理員檢查讀者提供的借閱卡,如果該借閱證真實(shí)準(zhǔn)確,讀者已經(jīng)借閱的圖書(shū)并沒(méi)有超過(guò)允許借書(shū)量,而且讀者沒(méi)有逾期未還的圖書(shū),則允許讀者借書(shū),否則,讀者不能從圖書(shū)館借書(shū)。讀者拿到要借閱的圖書(shū),同時(shí)拿到自己的借閱卡,借書(shū)過(guò)程完畢。當(dāng)借閱圖書(shū)的數(shù)量超過(guò)5本或者出現(xiàn)未按期歸還圖書(shū)的情況,則不好進(jìn)行借閱處理。圖書(shū)館的另一基本功能就是為讀者提供還書(shū)服務(wù),讀者在一本圖書(shū)借閱期滿之前把該圖書(shū)還給圖書(shū)館,一般的還書(shū)步驟如下:讀者把所借的圖書(shū)和自己的借閱卡交給圖書(shū)管理員。圖書(shū)管理員對(duì)圖書(shū)進(jìn)行檢查,看有無(wú)損壞,如果出現(xiàn)圖書(shū)的損壞情況,讀者應(yīng)進(jìn)行相應(yīng)的賠償。圖書(shū)管理員查看是否超過(guò)規(guī)定借閱期限,如果已經(jīng)過(guò)期,則讀者要按規(guī)定交納罰金。圖書(shū)管理員進(jìn)行登記,同時(shí)把還書(shū)信息記入借閱卡。讀者拿回自己的借閱卡,還書(shū)過(guò)程借書(shū)。讀者逾期未歸還圖書(shū)超過(guò)三天,將按照每本每天進(jìn)行一定的罰款。

      4、書(shū)籍掛失:對(duì)圖書(shū)由于丟失而不能即時(shí)還書(shū)的情況,讀者要即時(shí)到圖書(shū)管理員進(jìn)行登記,確保圖書(shū)信息的更新。進(jìn)行書(shū)籍掛失的步驟一般如下:讀者將所丟圖書(shū)信息告訴圖書(shū)管理員并將借閱卡交給圖書(shū)管理員。圖書(shū)管理員對(duì)該圖書(shū)信息進(jìn)行登記,并按圖書(shū)的價(jià)格,要求讀者進(jìn)行相應(yīng)賠償。圖書(shū)管理員將信息記入借閱卡。讀者拿回自己的借閱卡,掛失功能結(jié)束。

      2.2.2讀者管理功能

      1、辦理借閱卡:圖書(shū)館向讀者提供借閱服務(wù),讀者必須具有有效憑證方可借閱。因此,讀者必須辦理借閱卡獲取有效憑證。讀者在辦理借閱卡時(shí),必須輸入個(gè)人有關(guān)注冊(cè)信息,包括讀者姓名、性別、出生日期、家庭住址、身份證號(hào)碼、電話號(hào)碼等信息。系統(tǒng)根據(jù)讀者提供的信息,辦理借閱卡并生成個(gè)人帳號(hào)、讀者可自行修改密碼。

      2、借閱卡信息查詢;圖書(shū)館在正常運(yùn)營(yíng)中要面對(duì)大量的讀者信息,需要掌握每個(gè)讀者的信息,即時(shí)準(zhǔn)確的掌握讀者的基本情況,這些是圖書(shū)館運(yùn)營(yíng)的保證。讀者要進(jìn)行信息查詢,可以通過(guò)系統(tǒng)將自己的借閱卡賬戶、密碼輸入系統(tǒng),系統(tǒng)通過(guò)核對(duì)找到讀者的信息。如果讀者的信息正確,系統(tǒng)將讀者的信息包括讀者姓名、性別、出生日期、家庭住址、身份證號(hào)碼、電話號(hào)碼等信息。如果讀者的信息不正確,系統(tǒng)將提示錯(cuò)誤,并且系統(tǒng)設(shè)定,當(dāng)錯(cuò)誤次數(shù)超過(guò)5次時(shí),系統(tǒng)將不予查詢。

      3、借閱卡掛失:對(duì)借閱卡的丟失要即時(shí)進(jìn)行掛失處理,以防止其他人盜用自己的有效信息并出現(xiàn)私自借書(shū)等行為。借閱卡掛失的一般步驟可分為:讀者將掛失情況即時(shí)到圖書(shū)管理員處進(jìn)行登記,并填寫(xiě)登記單。圖書(shū)管理員將讀者情況進(jìn)行登記掛失,注銷(xiāo)借閱卡的信息,并咨詢讀者是否重新辦理。若讀者需重新辦理,則重新填寫(xiě)相關(guān)信息,系統(tǒng)自動(dòng)生成心的借閱卡信息記錄,讀者重新設(shè)置帳號(hào)即密碼,并交納相應(yīng)的費(fèi)用。若讀者不需辦理,則系統(tǒng)將信息注銷(xiāo)。讀者獲得新的圖書(shū)借閱卡。

      2.2.3系統(tǒng)管理功能

      1、注冊(cè)管理員:為了對(duì)圖書(shū)館管理系統(tǒng)進(jìn)行管理,圖書(shū)館需要若干名圖書(shū)管理員進(jìn)行管理,在圖書(shū)管理員對(duì)系統(tǒng)進(jìn)行管理之前必須進(jìn)行注冊(cè)功能,以確定管理員身份。對(duì)管理員進(jìn)行注冊(cè),系統(tǒng)生成相應(yīng)信息。其中管理員的基本信息包括:成員ID、密碼等。系統(tǒng)管理員每次登陸前輸入自己的ID與密碼,系統(tǒng)對(duì)其信息進(jìn)行核實(shí),如基本信息正確,則系統(tǒng)管理員可進(jìn)行系統(tǒng)管理功能,若系統(tǒng)檢查不正確,則系統(tǒng)管理員不可以進(jìn)行相應(yīng)的操作。

      2、修改密碼:服務(wù)圖書(shū)館管理員可能由于某些原因,如電腦中毒導(dǎo)致管理員密碼的泄露,為避免圖書(shū)管理信息遭到破壞,系統(tǒng)具有修改密碼的功能,確保圖書(shū)管理功能的安全性。

      3、退出功能:系統(tǒng)管理員每次離開(kāi)必須進(jìn)行退出功能,確保管理功能不被他人所用,這樣更方便圖書(shū)管理系統(tǒng)出現(xiàn)問(wèn)題時(shí),找到責(zé)任人。

      第三章 概要設(shè)計(jì)

      3.1總體設(shè)計(jì)

      3.1.1系統(tǒng)目標(biāo)設(shè)計(jì)

      系統(tǒng)開(kāi)發(fā)的總目標(biāo)是實(shí)現(xiàn)內(nèi)部圖書(shū)借閱管理的系統(tǒng)化、規(guī)范化和自動(dòng)化。能夠?qū)D書(shū)進(jìn)行注冊(cè)登記,也就是將圖書(shū)的基本信息(如:書(shū)名、作者、價(jià)格等)

      預(yù)先存入數(shù)據(jù)庫(kù)中,供以后檢索。能夠?qū)栝喨诉M(jìn)行注冊(cè)登記,包括記錄借閱人的姓名、地址、電話等信息。提供方便的查詢方法。如:以書(shū)名、作者、出版社、出版時(shí)間(確切的時(shí)間、時(shí)間段、某一時(shí)間之前、某一時(shí)間之后)等信息進(jìn)行圖書(shū)檢索,并能反映出圖書(shū)的借閱情況;以借閱人編號(hào)對(duì)借閱人信息進(jìn)行檢索;以出版社名稱(chēng)查詢出版社聯(lián)系方式信息。提供統(tǒng)計(jì)分析功能??梢哉宫F(xiàn)出圖書(shū)類(lèi)型比例、庫(kù)存與借出比例。提供舊書(shū)銷(xiāo)毀功能,對(duì)于淘汰、損壞、丟失的書(shū)目可及時(shí)對(duì)數(shù)據(jù)庫(kù)進(jìn)行修改。能夠?qū)κ褂迷摴芾硐到y(tǒng)的用戶進(jìn)行管理,按照不同的工作職能提供不同的功能授權(quán)。提供較為完善的差錯(cuò)控制與友好的用戶界面,盡量避免誤操作。3.1.2系統(tǒng)功能分析

      根據(jù)以上功能,將圖書(shū)管理系統(tǒng)的數(shù)據(jù)分為:數(shù)據(jù)輸入部分:主要包括圖書(shū)基本信息的錄入、借閱人基本信息的錄入、用戶基本信息的錄入。數(shù)據(jù)輸出部分:主要是各種統(tǒng)計(jì)查詢,包括:根據(jù)圖書(shū)信息(如書(shū)名、作者、出版社等)查閱圖書(shū)及其借閱信息、統(tǒng)計(jì)輸出圖書(shū)類(lèi)型比例等。數(shù)據(jù)處理部分:主要涉及借閱和歸還的處理,如一本書(shū)借出后,必須在數(shù)據(jù)

      庫(kù)中將該書(shū)標(biāo)記為已借出,以防出現(xiàn)數(shù)據(jù)庫(kù)中有書(shū)但圖書(shū)館無(wú)書(shū)的情況;一本書(shū)歸還后,同樣必須在數(shù)據(jù)庫(kù)中將其標(biāo)記為已經(jīng)歸還,以便再次借出。

      概念設(shè)計(jì)階段主要任務(wù)和目標(biāo)是根據(jù)需求分析的結(jié)果,包括一般聯(lián)系實(shí)體,畫(huà)出對(duì)應(yīng)的ER圖。對(duì)于復(fù)雜的系統(tǒng),通常首先要對(duì)它的各功能模進(jìn)行分析,然后再把它的功能結(jié)構(gòu)圖畫(huà)出來(lái),便是設(shè)計(jì)和優(yōu)化。功能分析之后,再根據(jù)各個(gè)崗位、各個(gè)用戶對(duì)數(shù)據(jù)和使用權(quán)限的不同要求作出局部ER圖,然后再把各個(gè)局部ER圖綜合起來(lái)形成統(tǒng)一的整體ER圖。

      3.2系統(tǒng)設(shè)計(jì)思想

      1、圖書(shū)管理系統(tǒng)是典型的信息管理系統(tǒng)(MIS),其開(kāi)發(fā)主要包括后臺(tái)數(shù)據(jù)庫(kù)的建立和維護(hù)以及前端應(yīng)用程序的開(kāi)發(fā)兩個(gè)方面。圖書(shū)管理系統(tǒng)使用的是SQL Server2000的數(shù)據(jù)管理系統(tǒng)和以Visual Basic6.0為開(kāi)發(fā)工具。

      2、首先進(jìn)行系統(tǒng)設(shè)計(jì)分析,系統(tǒng)設(shè)計(jì)主要包括系統(tǒng)功能分析、系統(tǒng)模塊設(shè)計(jì)以及運(yùn)行環(huán)境的選擇、系統(tǒng)實(shí)現(xiàn)過(guò)程。

      3、然后根據(jù)系統(tǒng)功能分析設(shè)計(jì)出需要的數(shù)據(jù)庫(kù),繪制系統(tǒng)數(shù)據(jù)流圖與總結(jié)數(shù)據(jù)字典、設(shè)計(jì)數(shù)據(jù)庫(kù)結(jié)構(gòu)。

      4、最后在實(shí)現(xiàn)各個(gè)功能模塊時(shí),采用先模塊后系統(tǒng)集成的方式,即各系統(tǒng)功能模塊分別獨(dú)立設(shè)計(jì)和調(diào)試,在創(chuàng)建系統(tǒng)主窗體時(shí)才將各個(gè)功能模塊通過(guò)主窗體菜單系統(tǒng)集成到一起,最后進(jìn)行系統(tǒng)整體的設(shè)計(jì)和調(diào)試。

      3.3 系統(tǒng)模塊功能解析

      (1)系統(tǒng)設(shè)計(jì)分析

      本圖書(shū)管理系統(tǒng)主要有以下功能: 圖書(shū)征訂:包括圖書(shū)征訂數(shù)據(jù)的錄入、修改、刪除與審校等功能。圖書(shū)編目:包括圖書(shū)數(shù)目信息的錄入、修改、刪除功能。圖書(shū)典藏:包括新書(shū)分配、庫(kù)室調(diào)配等功能。

      圖書(shū)流通:包括圖書(shū)借閱、續(xù)借、圖書(shū)返還,圖書(shū)書(shū)目的查詢的功能。系統(tǒng)用戶管理:包括系統(tǒng)用戶數(shù)據(jù)的錄入、修改與刪除等功能。

      讀者數(shù)據(jù)管理:包括讀者類(lèi)別管理,讀者個(gè)人數(shù)據(jù)的錄入、修改和刪除功能。(2)系統(tǒng)功能分析

      權(quán)限功能:權(quán)限功能設(shè)置的對(duì)象為高級(jí)管理員、普通管理員、讀者。高級(jí)管 刪除所有信息;普通管理員只能對(duì)授權(quán)范圍內(nèi)進(jìn)行相應(yīng)修改及刪除;讀者 只能查詢借閱記錄和圖書(shū)書(shū)目不能修改。

      錄入功能:為普通管理員提供相應(yīng)的錄入功能,為高級(jí)管理員提供對(duì)所有信息的錄入功能。

      查詢功能:為所有用戶提供查詢的功能,可查詢?cè)试S范圍內(nèi)的所有信息。維護(hù)功能:為普通管理員提供查詢及相應(yīng)的修改,刪除功能,為高級(jí)管理提 供對(duì)所有信息的修改刪除功能。

      打印功能:可打印圖書(shū)征訂計(jì)劃。

      退出功能:各個(gè)功能模塊和主窗體都設(shè)有關(guān)閉命令按鈕,可方便地退出各模 塊或系統(tǒng)。

      第四章 詳細(xì)設(shè)計(jì)

      4.1程序設(shè)計(jì)說(shuō)明

      4.1.1用戶登錄模塊

      1.程序描述:此程序用于用戶登陸的至用戶界面,程序通過(guò)輸入用戶的ID,用戶密碼的正確性來(lái)實(shí)現(xiàn)對(duì)驗(yàn)證用戶的真實(shí)性。2.功能:實(shí)現(xiàn)用戶的登錄功能

      3.性能:用戶通過(guò)輸入用戶ID,用戶名和密碼進(jìn)行用戶登陸,通過(guò)認(rèn)證后,用戶

      即可進(jìn)入用戶界面。

      4.輸入項(xiàng):輸入用戶ID,用戶名,密碼5.輸出項(xiàng):用戶主頁(yè)面。流程邏輯如圖所示:

      輸入用戶名和密碼N數(shù)據(jù)庫(kù)是否打開(kāi)Y連接失敗返回N用戶名和密碼是否正確Y輸入次數(shù)是否超過(guò)5次YN重新輸入密碼關(guān)閉數(shù)據(jù)庫(kù)返回登陸成功進(jìn)入主界面

      圖4-1用戶登錄流程邏輯

      4.1.2用戶添加模塊

      1.程序描述:此程序用于添加新的用戶,用戶通過(guò)向數(shù)據(jù)庫(kù)內(nèi)輸入必要的信息來(lái)注冊(cè)成為新的用戶,才通過(guò)一系列的驗(yàn)證之后,即注冊(cè)成為真正的用戶。

      2.功能:實(shí)現(xiàn)對(duì)用戶的添加功能。

      3.性能:查詢新用戶的用戶名是否存在,若存在則停止添加返還數(shù)據(jù)庫(kù);若用戶不存在,則進(jìn)行添加,并進(jìn)行注冊(cè),注冊(cè)成功后返回。

      4.輸入項(xiàng):輸入用戶的詳細(xì)信息,包括姓名,出生日期,性別,地址,身份證號(hào)碼,電話號(hào)碼等信息。

      5.輸出項(xiàng):若添加成功,則輸出提示用戶注冊(cè)成功界面;若未成功,則提示輸出未成功原因界面。

      6.流程邏輯如下圖所示:

      輸入用戶信息N判斷數(shù)據(jù)庫(kù)是否打開(kāi)提示連接失敗返回Y查詢數(shù)據(jù)庫(kù)中是否有該用戶Y提示已經(jīng)存在該用戶關(guān)閉數(shù)據(jù)庫(kù)并返回N向數(shù)據(jù)庫(kù)中添加新用戶提示注冊(cè)成功返回

      圖4-2用戶添加模塊流程邏輯

      4.1.3書(shū)籍查詢模塊

      1.程序描述:此程序用于實(shí)現(xiàn)用戶對(duì)想要借閱的查詢功能。用戶通過(guò)輸入相應(yīng)的圖書(shū)信息來(lái)查詢,數(shù)據(jù)庫(kù)根據(jù)用戶提供的信息來(lái)搜索,最后給出客戶相應(yīng)的圖書(shū)信息。

      2.功能:實(shí)現(xiàn)圖書(shū)查詢功能。

      3.性能:對(duì)進(jìn)行想要查詢的書(shū)籍進(jìn)行搜索,若存在此書(shū)則顯示該書(shū)的詳細(xì)信息;若不存在此書(shū),則提示沒(méi)有此書(shū)并返回。

      4.輸入項(xiàng):輸入圖書(shū)的詳細(xì)信息,包括圖書(shū)名稱(chēng),書(shū)籍ID,圖書(shū)作者,出版社,單價(jià)等信息。

      5.輸出項(xiàng):若輸入的圖書(shū)存在即輸出圖書(shū)詳細(xì)信息界面;若輸入的圖書(shū)不存在則顯示圖書(shū)不存在界面。

      6.流程邏輯如下圖所示:

      輸入圖書(shū)信息判斷數(shù)據(jù)庫(kù)是否打開(kāi)Y查詢是否有該書(shū)YN連接失敗返回N關(guān)閉數(shù)據(jù)庫(kù)返回顯示該書(shū)的信息關(guān)閉數(shù)據(jù)庫(kù)返回 圖4-3圖書(shū)查詢模塊流程

      4.1.4圖書(shū)借閱模塊

      1.程序描述:此程序用于圖書(shū)的借閱,用戶通過(guò)登錄自己的借閱ID后,對(duì)需要借閱的圖書(shū)進(jìn)行借閱操作,如果符合借閱的要求,則可進(jìn)行借閱。2.功能:實(shí)現(xiàn)對(duì)圖書(shū)的書(shū)籍借閱功能。

      3.性能:首先驗(yàn)證借閱者輸入的借閱ID是否存在,若存在進(jìn)行下一步;若不存在則返回。

      4.若借閱ID存在,則檢查此借閱ID是否借閱書(shū)籍超出4本,若超出則提示超出借閱數(shù)目,返回;若沒(méi)有超出,則進(jìn)行下一操作。

      5.對(duì)想要借閱的圖書(shū)ID進(jìn)行搜索,若此書(shū)不存在,則提示此書(shū)不存在;若此書(shū)存在則進(jìn)行下一步操作。

      將借閱者借閱的數(shù)量増一,將數(shù)據(jù)庫(kù)中此書(shū)數(shù)量減一,同時(shí)提醒借閱成功,然后返回。

      6.輸入項(xiàng):輸入借閱證的ID,圖書(shū)ID 7.輸出項(xiàng):若借閱證ID正確且圖書(shū)ID正確且符合借閱要求,則輸出提示借閱成功界面;若存在借閱ID或圖書(shū)ID或不符合借閱要求等問(wèn)題,則輸出提示沒(méi)有借閱成功原因的界面。8.流程邏輯如下圖

      輸入書(shū)籍ID和借閱IDN數(shù)據(jù)庫(kù)是否打開(kāi)YN借閱卡ID是否存在YY判斷借閱ID是否借書(shū)超出4本提示超出最大借書(shū)數(shù)量關(guān)閉數(shù)據(jù)庫(kù)返回提示不存在該借閱者關(guān)閉數(shù)據(jù)庫(kù)返回?cái)?shù)據(jù)庫(kù)連接失敗返回NN數(shù)據(jù)庫(kù)中是否存在書(shū)籍IDY將借閱者的借書(shū)數(shù)量加1提示不存在該書(shū)籍關(guān)閉數(shù)據(jù)庫(kù)返回將書(shū)籍的數(shù)量減1提示借書(shū)成功關(guān)閉數(shù)據(jù)庫(kù)返回 圖4-4圖書(shū)借閱模塊

      4.1.5圖書(shū)歸還模塊

      1.程序描述:此程序用于圖書(shū)的歸還,用戶在登錄自己的ID之后,用戶可以對(duì)需要?dú)w還的圖書(shū)進(jìn)行操作,如果符合歸還要求,則可以將圖書(shū)歸還。2.功能:實(shí)現(xiàn)對(duì)圖書(shū)的書(shū)籍歸還功能。

      3.性能:首先驗(yàn)證借閱者輸入的借閱ID是否存在,若存在進(jìn)行下一步;若不存在則返回。

      對(duì)想要?dú)w還的圖書(shū)ID進(jìn)行搜索,若此書(shū)不存在,則提示此書(shū)不存在;若此書(shū)存在則進(jìn)行下一步操作。將借閱者借閱的數(shù)量減一,將數(shù)據(jù)庫(kù)中此書(shū)數(shù)量加一,同時(shí)提醒借閱歸還,然后返回。

      4.輸入項(xiàng):輸入借閱證ID和圖書(shū)ID 5.輸出項(xiàng):若借閱證ID和圖書(shū)ID正確,則輸出提示圖書(shū)歸還成功界面;若借閱證ID或圖書(shū)ID不正確,則輸出提示沒(méi)有成功原因的界面。

      6.流程邏輯如下圖:

      輸入書(shū)籍ID和借閱IDN數(shù)據(jù)庫(kù)是否打開(kāi)YN借閱卡ID是否存在YN提示不存在該書(shū)籍關(guān)閉數(shù)據(jù)庫(kù)返回提示不存在該借閱者關(guān)閉數(shù)據(jù)庫(kù)返回?cái)?shù)據(jù)庫(kù)連接失敗返回?cái)?shù)據(jù)庫(kù)中是否存在書(shū)籍IDY將借閱者的借書(shū)數(shù)量減1將書(shū)籍的數(shù)量加1提示還書(shū)成功關(guān)閉數(shù)據(jù)庫(kù)返回 圖4-5圖書(shū)歸還模塊

      4.1.6新書(shū)入庫(kù)模塊

      1.程序描述:此程序用戶對(duì)新進(jìn)圖書(shū)的入口登記處理。用戶可以將新書(shū)的詳細(xì)信息進(jìn)行輸入,保存在數(shù)據(jù)庫(kù)中后,新書(shū)即登記成功。

      2.功能;實(shí)現(xiàn)新進(jìn)圖書(shū)入庫(kù)功能。

      3.性能:對(duì)數(shù)據(jù)庫(kù)查詢是否已存在此書(shū),若存在則將此書(shū)數(shù)量加一,提示添加成功;若沒(méi)有此書(shū),則將此書(shū)的基本信息存入數(shù)據(jù)庫(kù),并提示添加書(shū)籍成功。

      4.輸入項(xiàng):輸入新書(shū)的書(shū)籍ID,書(shū)名,作者,出版社,單價(jià)等信息。

      5.輸出項(xiàng):若添加成功,則輸出提示新書(shū)添加成功界面;若沒(méi)有添加成功,輸出提示未成功原因界面。

      6.流程邏輯如下圖

      輸入書(shū)籍信息N數(shù)據(jù)庫(kù)是否打開(kāi)關(guān)閉數(shù)據(jù)庫(kù)返回Y是否已經(jīng)存在Y該書(shū)將該書(shū)的數(shù)量加1提示添加書(shū)籍成功關(guān)閉數(shù)據(jù)庫(kù)N將該書(shū)信息存入數(shù)據(jù)庫(kù)是否是第一條N記錄提示添加書(shū)籍成功關(guān)閉數(shù)據(jù)庫(kù)返回Y提示添加第一本書(shū)籍關(guān)閉數(shù)據(jù)庫(kù)返回圖4-6新書(shū)入庫(kù)模塊

      返回

      第五章 編碼與測(cè)試

      5.1各功能模塊的實(shí)現(xiàn)

      (1)用戶登錄窗體

      圖5-1 用戶登錄窗體

      用戶登錄代碼:

      Const MaxLogTimes As Integer = 3 Private Sub cmdcancel_Click()

      If MsgBox(“是否真的退出系統(tǒng)登錄?”, vbYesNo, “登錄驗(yàn)證”)= vbYes Then

      Unload Me

      End If End Sub Private Sub cmdok_Click()

      Static intLogTimes As Integer

      intLogTimes = intLogTimes + 1

      If intLogTimes > MaxLogTimes Then

      MsgBox “超過(guò)登錄次數(shù)!”, vbCritical, “登錄驗(yàn)證”

      Else

      With Library_Manage.rsSysUsers

      .Open

      If.RecordCount > 0 Then

      .MoveFirst

      .Find “編號(hào)=” & Trim(txtLog(0))& “"

      If.EOF Then

      MsgBox Trim(txtLog(0))& ”不是系統(tǒng)用戶,請(qǐng)檢查輸入!“, vbCritical, ”登錄驗(yàn)證“

      txtLog(0).SetFocus

      txtLog(0).SelStart = 0

      txtLog(0).SelLength = Len(txtLog(0))

      ElseIf.Fields(”口令“)<> Trim(txtLog(1))Then

      MsgBox ”口令錯(cuò)誤,請(qǐng)檢查輸入口令!“, vbCritical, ”登錄驗(yàn)證“

      txtLog(1).SetFocus: txtLog(1)= ”“

      Else

      CurrentUserNum =.Fields(編號(hào))

      CurrentUserPassword =.Fields(”口令“)

      CurrentUserStatus =.Fields(”權(quán)限“)

      MsgBox ”歡迎使用常州信息學(xué)院管理系統(tǒng)!“, vbInformation, ”登陸成功!“

      Unload Me

      End If

      End If

      .Close

      End With

      End If End Sub Private Sub Form_Load()

      SysLogon.BackColor = RGB(192, 210, 270)End Sub(2)用戶管理窗體界面

      圖5-2 用戶管理窗體

      用戶管理窗體代碼 '保存

      Private Sub cmdSave_Click()

      Dim objcopy As New Recordset

      If Trim(txtNum)= ”“ Then

      MsgBox ”不能為空!“, vbCritical, ”系統(tǒng)用戶管理“

      txtNum.SetFocus

      txtNum.SelStart = 0

      txtNum.SelLength = Len(txtNum)

      ElseIf Len(Trim(txtPwd))<> 6 Then

      MsgBox ”用戶口令須為6位字符串!“, vbCritical, ”系統(tǒng)用戶管理“

      txtPwd.SetFocus

      txtPwd.SelStart = 0

      txtPwd.SelLength = Len(txtPwd)ElseIf Not txtAuth Like ”[0,1]“ Then

      MsgBox ”用戶權(quán)限必須為0或1“, vbCritical, ”系統(tǒng)用戶管理“

      txtAuth = ”“

      txtAuth.SetFocus Else

      Set objcopy = Library_Manage.rsSysUsers.Clone '對(duì)錯(cuò)?

      With objcopy

      If.RecordCount > 0 Then

      .MoveFirst

      .Find ”編號(hào)“ & Trim(txtNum)& ”“

      If Not.EOF And.AbsolutePosition <> Library_Manage.rsSysUsers.AbsolutePosition Then

      MsgBox ”編號(hào):“ & Trim(txtNum)& ”已被使用,請(qǐng)選擇其他編號(hào)!“, vbCritical, ”系統(tǒng)用戶管理“

      txtNum.SetFocus

      txtNum.SelStart = 0

      txtNum.SelLength = Len(txtNum)

      Exit Sub

      Else

      '保存記錄

      Library_Manage.rsSysUsers.Update

      MsgBox ”數(shù)據(jù)保存成功!“, vbInformation, ”系統(tǒng)用戶管理“

      cmdAdd.Enabled = True

      cmdDel.Enabled = True

      isAdding = False: picNavigation.Enabled = True

      End If

      End With End If End Sub Private Sub Form_Load()

      cmdMove(0).Value = True End Sub(3)讀者數(shù)據(jù)管理窗體界面

      圖5-3 讀者數(shù)據(jù)管理窗體

      讀者數(shù)據(jù)管理窗體代碼

      Library_Manage.Library_Manage_Con.Execute ”TRUNCATE TABLE 讀者類(lèi)別“

      With Library_Manage.ReaderType

      If.State = adStateClosed Then.Open

      .AddNew

      .Fields(”編號(hào)“)= ”0“

      .Fields(”名稱(chēng)“)= ”特殊“

      .Fields(”借書(shū)量“)= Val(txtSp(1))

      .Fields(”借書(shū)期“)= Val(txtSp(2))

      .Fields(”有效期“)= Val(txtSp(3))

      .Update

      .AddNew

      .Fields(”編號(hào)“)= ”1“

      .Fields(”名稱(chēng)“)= ”館員“

      .Fields(”借書(shū)量“)= Val(txtL(1))

      .Fields(”借書(shū)期“)= Val(txtL(2))

      .Fields(”有效期“)= Val(txtL(3))

      .Update

      .AddNew

      .Update

      .AddNew

      .Fields(”編號(hào)“)= ”2“

      .Fields(”名稱(chēng)“)= ”教師“

      .Fields(”借書(shū)量“)= Val(txtT(1))

      .Fields(”借書(shū)期“)= Val(txtT(2))

      .Fields(”有效期“)= Val(txtT(3))

      .Update

      .AddNew

      .Fields(”編號(hào)“)= ”3“

      .Fields(”名稱(chēng)“)= ”學(xué)生“

      .Fields(”借書(shū)量“)= Val(txtS(1))

      .Fields(”借書(shū)期“)= Val(txtS(2))

      .Fields(”有效期“)= Val(txtS(3))

      .Update

      End With End Sub Private Sub Form_Load()cmdMove(0).Value = True End Sub Private Sub SSTab1_DblClick()End Sub(4)圖書(shū)征訂管理窗體

      圖5-4 圖書(shū)征訂管理窗體

      圖書(shū)征訂管理代碼

      txtPubDate.SelLength = Len(txtPubDate)

      ElseIf Trim(txtAuthor)= ”“ Then

      MsgBox ”作者不能為空!“, vbCritical, ”圖書(shū)征訂管理“

      txtAuthor.SetFocus

      txtAuthor.SelStart = 0

      txtAuthor.SelLength = Len(txtAuthor)

      ElseIf Val(txtNum)= ”“ Then

      MsgBox ”正的數(shù)量無(wú)效!“, vbCritical, ”圖書(shū)征訂管理“

      txtNum.SetFocus

      txtNum.SelStart = 0

      txtNum.SelLength = Len(txtNum)

      ElseIf Not IsDate(txtDate)= ”“ Then

      MsgBox ”作者不能為空!“, vbCritical, ”圖書(shū)征訂管理“

      txtDate.SetFocus

      txtDate.SelStart = 0

      txtDate.SelLength = Len(txtDate)

      Else

      '保存記錄

      Library_Manage.rsBooksOrder.Update

      MsgBox ”數(shù)據(jù)保存成功!“, vbInformation, ”圖書(shū)征訂管理“

      cmdAdd.Enabled = True: cmdDel.Enabled = True

      cmdExam.Enabled = True: cmdRefresh.Enabled = True

      isAdding = False: picNavigation.Enabled = True

      End If End Sub Dim objcopy As Recordset Private Sub cmbOut_Click()

      AddListOut

      End Sub Private Sub cmdAddAll_Click(Index As Integer)'選擇全部條碼

      ListItem_Add lstPre(Index), LstIn(Index), Index, True End Sub Private Sub cmdAddOne_Click(Index As Integer)'選擇當(dāng)前條碼

      ListItem_Add lstPre(Index), LstIn(Index), Index, False End Sub Private Sub cmdExit_Click()

      If LstIn(0).ListCount > 0 Then

      If MsgBox(”你選定了部分新書(shū)準(zhǔn)備入庫(kù),但沒(méi)執(zhí)行保存操作“ & vbCr & ”是否要執(zhí)行保存操作?“, vbCritical + vbYesNo, ”圖書(shū)典藏管理“)= vbYes Then

      SSTab1.Tab = 0

      cmdSave.Value = True

      End If

      ElseIf LstIn(1).ListCount > 0 Then

      If MsgBox(”你選定了部分新書(shū)準(zhǔn)備入庫(kù),但沒(méi)執(zhí)行保存操作“ & vbCr & ”是否要執(zhí)行保存操作?“, vbCritical + vbYesNo, ”圖書(shū)典藏管理“)= vbYes Then

      SSTab1.Tab = 1

      cmdSave.Value = True

      End If

      End If

      Unload Me End Sub '刷新新書(shū)或調(diào)出庫(kù)室條碼列表

      Private Sub cmdRefresh_Click(Index As Integer)

      Select Case Index

      Case 0 '刷新新書(shū)列表

      With Library_Manage.rsBooksBibli

      If.State = adStateClosed Then.Open

      .Requery

      End With

      AddListNew

      Case 1 '刷新庫(kù)室條碼列表

      With Library_Manage.rsBooksStore

      If.State = adStateClosed Then.Open

      .Requery

      End With

      AddListOut

      End Select End Sub Public Sub AddListNew()

      lstPre(0).Clear

      With Library_Manage.rsBooksBibli

      If.State = adStateClosed Then.Open

      If.RecordCount > 0 Then

      .MoveFirst

      While Not.EOF

      lstPre(0).AddItem.Fields(”條碼“)

      .MoveNext

      Wend

      Else

      lstPre(0).AddItem ”當(dāng)前無(wú)待分配新書(shū)"

      End If End With End Sub 5.2 測(cè)試

      5.2.1 借閱卡管理測(cè)試

      進(jìn)度安排測(cè)試辦理借閱證信息,檢查個(gè)人賬號(hào)、讀者可自行修改密碼。測(cè)試查詢借閱卡信息的正確性,包括輸入的讀者信息等。測(cè)試借閱卡掛失功能,包括讀者信息等。

      5.2.2 書(shū)籍管理測(cè)試

      進(jìn)度安排:測(cè)試新書(shū)入庫(kù)信息的正確性。測(cè)試借書(shū)、還書(shū)功能信息正確性。測(cè)試書(shū)籍掛失信息的正確性。測(cè)試圖書(shū)信息查詢的正確性。測(cè)試借書(shū)信息查詢的正確性。

      5.2.3 系統(tǒng)管理測(cè)試

      進(jìn)度安排測(cè)試注冊(cè)管理員信息的正確性。測(cè)試修改密碼信息的正確性。

      結(jié)束語(yǔ)

      對(duì)于這篇論文我有不少心得體會(huì)。這次是對(duì)我們掌握所學(xué)知識(shí)的一次考核。它可以讓我們了解自己一學(xué)期里的學(xué)習(xí)情況,有助于在今后的學(xué)習(xí)中加以改進(jìn)。通過(guò)這次上機(jī)實(shí)驗(yàn),我發(fā)現(xiàn)了自己對(duì)數(shù)據(jù)庫(kù)和vb語(yǔ)言掌握的并不牢,有的知識(shí)點(diǎn)根本就不懂。這都要怪自己在平時(shí)的學(xué)習(xí)過(guò)程中不夠用心,不懂的地方也沒(méi)有及時(shí)的去搞懂,課后也沒(méi)怎么花時(shí)間去研究。這次實(shí)驗(yàn)我覺(jué)得自己不僅學(xué)到了很多軟件設(shè)計(jì)方面的知識(shí),也讓我鞏固了以前所學(xué)的知識(shí)以及看到了自己以前學(xué)習(xí)中的不足之處。

      在今后的學(xué)習(xí)過(guò)程中,我一定會(huì)認(rèn)真學(xué)習(xí)專(zhuān)業(yè)課程,再也不能像以前那樣迷迷糊糊的,課后要多花時(shí)間去研究一些有關(guān)編程方面的題目,不懂的地方及時(shí)把它弄懂。以后自己還要多動(dòng)手編寫(xiě)一些程序。在這里我要感謝學(xué)校能提供這么一個(gè)寶貴的機(jī)會(huì),我們可以把課堂上所學(xué)的理論知識(shí)運(yùn)用到實(shí)踐中去,把書(shū)上的東西變成我們自己的。這個(gè)機(jī)會(huì)既讓我們學(xué)習(xí)鞏固了知識(shí),也讓我們發(fā)現(xiàn)了自己的不足之處。特別要感謝我們的指導(dǎo)老師,正因?yàn)橛辛四膸椭覀儾趴梢酝瓿蓪?shí)驗(yàn)。我也希望今后還會(huì)有更多的機(jī)會(huì)讓我們?nèi)?shí)踐,去充實(shí)自己。

      致 謝

      在本次設(shè)計(jì)的過(guò)程中,老師們給了我們很大的幫助。不僅使我們?cè)谝?guī)定時(shí)間內(nèi)完成了系統(tǒng)的設(shè)計(jì),同時(shí)還使我們學(xué)到了很多有益的知識(shí)和寶貴的經(jīng)驗(yàn)在此,我謹(jǐn)向他們表示最衷心的感謝。感謝老師的指導(dǎo),使我們充分利用軟件工程,VB,數(shù)據(jù)庫(kù)原理開(kāi)發(fā)出自己的項(xiàng)目.在開(kāi)發(fā)的過(guò)程中使我體會(huì)到了工程化開(kāi)發(fā)方法和瀑布模型利用的重要性,在此還要感謝所有合作參與項(xiàng)目開(kāi)發(fā)的同學(xué)們這次畢業(yè)設(shè)計(jì)的成功離不開(kāi)所有參與的同學(xué)們的幫助和支持,是他們讓我知道了團(tuán)隊(duì)工作的重要.參考文獻(xiàn)

      1、陶宏才.數(shù)據(jù)庫(kù)原理及設(shè)計(jì)[M].北京:清華大學(xué)出版社.2004.2、陸麗娜.軟件工程 [M].北京:經(jīng)濟(jì)科學(xué)出版社.1999

      3、郝志恒、劉舫.Visual Basic 6.0 編程篇[M] 北京:電子工業(yè)出版社 2004

      4、劉世峰.數(shù)據(jù)庫(kù)基礎(chǔ)與應(yīng)用[M] 北京: 中央電大出版社 2003

      5、吳斌、魯大林.Visual Basic+SQL Sever數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)開(kāi)發(fā)[M] 北京:機(jī)械工程出版社 2008

      6、邱李華.SQL Server 2000 數(shù)據(jù)庫(kù)應(yīng)用教程[M] 北京:人民郵電出版社 2007

      7、鐘軍.Visual Basic數(shù)據(jù)庫(kù)高級(jí)實(shí)例導(dǎo)航[M] 北京:清華大學(xué)出版社 2003

      8、趙松濤.Visual Basic+SQL Server 2000 系統(tǒng)開(kāi)發(fā)實(shí)錄[M] 北京: 機(jī)械工業(yè)出版社 2007

      第五篇:圖書(shū)管理系統(tǒng)

      圖書(shū)管理系統(tǒng)

      背景:當(dāng)今時(shí)代是飛速發(fā)展的信息時(shí)代,在各行各業(yè)中離不開(kāi)信息處理,這正是計(jì)算機(jī)被廣泛應(yīng)用于信息管理系統(tǒng)的環(huán)境。計(jì)算機(jī)的最大好處在于利用它能夠進(jìn)行信息管理。使用計(jì)算機(jī)進(jìn)行信息控制,不僅提高了工作效率,而且大大提高了其安全性。

      隨著圖書(shū)館的藏書(shū)、管理人員、讀者數(shù)量的不斷增多,如何對(duì)書(shū)籍以及讀者信息、讀者借閱信息進(jìn)行管理成為一個(gè)難題。圖書(shū)涉及大量的數(shù)據(jù)處理,如果用手工來(lái)完成龐大的數(shù)據(jù)處理,不僅費(fèi)時(shí)費(fèi)力,還容易出錯(cuò)。為了滿足圖書(shū)管理的需要,急需要一套圖書(shū)管理系統(tǒng)來(lái)完成這項(xiàng)工作。作為計(jì)算機(jī)應(yīng)用的一部分,使用計(jì)算機(jī)對(duì)圖書(shū)信息進(jìn)行管理,具有手工管理所無(wú)法比擬的優(yōu)點(diǎn)。例如:檢索迅速、查找方便、可靠性高、存儲(chǔ)量大、保密性好、壽命長(zhǎng)、成本低等。這些優(yōu)點(diǎn)能夠極大地提高圖書(shū)管理的效率,也是圖書(shū)館信息的科學(xué)化、正規(guī)化管理的重要條件。因此將詳細(xì)分析一個(gè)圖書(shū)館系統(tǒng)地實(shí)現(xiàn)過(guò)程。從需求分析、架構(gòu)設(shè)計(jì)、系統(tǒng)建模、詳細(xì)設(shè)計(jì)、代碼實(shí)現(xiàn)逐步展開(kāi)分析,整個(gè)過(guò)程按照軟件實(shí)際流程進(jìn)行。

      意義:通過(guò)學(xué)習(xí)JAVA語(yǔ)言,又加深對(duì)面向?qū)ο蠓治?,確定問(wèn)題域中的對(duì)象及對(duì)象間關(guān)系,并建立起問(wèn)題域的對(duì)象模型。面向?qū)ο蟮脑O(shè)計(jì)方法是一種進(jìn)行程序設(shè)計(jì)的新方法,它吸取了結(jié)構(gòu)化程序設(shè)計(jì)的先進(jìn)思想,為解決程序結(jié)構(gòu)過(guò)于復(fù)雜而產(chǎn)生。它的思想是在進(jìn)行程序設(shè)計(jì)時(shí),把整個(gè)問(wèn)題分成由相關(guān)部分組成的組,每個(gè)組考慮和組相關(guān)的代碼和數(shù)據(jù),同時(shí)這些分組將按層次關(guān)系組織起來(lái),每個(gè)分組轉(zhuǎn)換為對(duì)象的獨(dú)立單元。面向?qū)ο蟮某绦蛟O(shè)計(jì)語(yǔ)言都具有多態(tài)性、繼承性、封裝性等特點(diǎn)。學(xué)習(xí)以后對(duì)JAVA程序設(shè)計(jì)有了深入的了解,JAVA語(yǔ)言程序設(shè)計(jì)要求結(jié)構(gòu)緊湊,概念準(zhǔn)確。

      實(shí)踐項(xiàng)目:圖書(shū)管理系統(tǒng)。

      主要完成這個(gè)項(xiàng)目的,可以實(shí)現(xiàn)圖書(shū)系統(tǒng)的系統(tǒng)化和自動(dòng)化,幫助圖書(shū)管理人員更好更高效地完成圖書(shū)管理工作。需求分析:圖書(shū)管理系統(tǒng)需要滿足三方面的需求,這三個(gè)方面分別是圖書(shū)借閱者、圖書(shū)館工作人員和圖書(shū)館管理人員。圖書(shū)借閱者的需求是查詢圖書(shū)館所存的圖書(shū)、個(gè)人借閱情況及個(gè)人信息的修改;圖書(shū)館工作人員對(duì)圖書(shū)借閱者的借閱及還書(shū)要求進(jìn)行操作,同時(shí)形成借書(shū)或還書(shū)記錄;圖書(shū)館管理人員的功能最復(fù)雜,包括對(duì)圖書(shū)借閱者、圖書(shū)進(jìn)行管理和維護(hù),及系統(tǒng)狀態(tài)的查看、維護(hù)。

      圖書(shū)借閱者可直接查看圖書(shū)館圖書(shū)情況,如果圖書(shū)借閱者根據(jù)本人借書(shū)證號(hào)和密碼登錄系統(tǒng),還可以進(jìn)行本人借書(shū)情況的查詢并維護(hù)部分個(gè)人信息。一般情況下,圖書(shū)借閱者只應(yīng)該查詢和維護(hù)本人的借書(shū)情況和信息,若查詢和維護(hù)其他借閱者的借書(shū)情況和信息,就要知道其他圖書(shū)借閱者的借書(shū)證號(hào)和密碼。這些是很難得到的,特別是密碼,所以不但滿足了圖書(shū)借閱者的要求,還保護(hù)了圖書(shū)借閱者的個(gè)人隱私。

      圖書(shū)館工作人員有修改圖書(shū)借閱者借書(shū)和還書(shū)記錄的權(quán)限,在此模塊中,圖書(shū)館工作人員可以為圖書(shū)借閱者加入借書(shū)記錄或是還書(shū)記錄。

      圖書(shū)館管理人員功能的信息量大,數(shù)據(jù)安全性和保密性要求最高。本功能實(shí)現(xiàn)對(duì)圖書(shū)信息、借閱者信息、總體借閱情況信息的管理和信息查看及維護(hù)。圖書(shū)館管理員可以瀏覽、查詢、添加、刪除、修改圖書(shū)的基本信息;瀏覽、查詢、添加、刪除和修改圖書(shū)借閱者的基本信息,但不能添加、刪除和修改借閱信息,這部分功能應(yīng)該由圖書(shū)館工作人員執(zhí)行,但是,刪除某條圖書(shū)借閱者基本信息記錄時(shí),應(yīng)實(shí)現(xiàn)對(duì)該圖書(shū)借閱者借閱記錄的級(jí)聯(lián)刪除。

      功能如下:⑴書(shū)籍管理部分:主要包括讀者類(lèi)別和書(shū)籍信息管理兩部分。其中,書(shū)籍類(lèi)別管理包括添加書(shū)籍類(lèi)別、修改書(shū)籍類(lèi)別等;書(shū)籍信息管理包括書(shū)籍信息的添加、書(shū)籍信息的修改、書(shū)籍信息的查詢、書(shū)籍信息的刪除等。

      ⑵讀者管理部分:主要包括讀者類(lèi)別管理和讀者信息管理兩部分。其中,讀者類(lèi)別管理包括添加讀者類(lèi)

      別、修改讀者類(lèi)別等;讀者信息管理包括添加讀者信息、修改讀者信息、刪除讀者信息、查詢讀者信息等。

      ⑶借閱管理部分:主要包括借書(shū)信息管理和還書(shū)信息管理兩部分。其中,借書(shū)信息管理包括借書(shū)信息的添加、借書(shū)信息的修改、借書(shū)信息的查詢等;還書(shū)信息管理部分包括還書(shū)信息的添加、還書(shū)信息的修改、還書(shū)信息的查詢等。

      ⑷系統(tǒng)管理部分:包括修改系統(tǒng)用戶密碼、增加新用戶以及退出系統(tǒng)等

      所以,該圖書(shū)管理系統(tǒng)能夠是圖書(shū)管理員方便地管理圖書(shū)館內(nèi)的多種事務(wù),讓圖書(shū)館工作人員更有效地

      為讀者提供借閱、歸還書(shū)籍的服務(wù),也能夠?yàn)樽x者提供查詢書(shū)籍信息、個(gè)人借閱信息。

      數(shù)據(jù)庫(kù)流程分析:

      1.?dāng)?shù)據(jù)處理流程

      數(shù)據(jù)庫(kù)或數(shù)據(jù)表結(jié)構(gòu)確定之后,在實(shí)際的數(shù)據(jù)處理程序設(shè)計(jì)之前需要對(duì)所處理的數(shù)據(jù)處理流程作必要的分析。所謂對(duì)數(shù)據(jù)處理流程作必要的分析是指找出各數(shù)據(jù)之間的主要關(guān)系,數(shù)據(jù)存取的主要走向。另外,在實(shí)際的數(shù)據(jù)處理過(guò)程中還會(huì)有些細(xì)節(jié)問(wèn)題。在遇到這些細(xì)節(jié)問(wèn)題時(shí),及時(shí)處理即可。并且,有些細(xì)節(jié)問(wèn)題不是在做數(shù)據(jù)處理流程分析時(shí)事先都能預(yù)料的。對(duì)于現(xiàn)在這個(gè)數(shù)據(jù)處理系統(tǒng)來(lái)說(shuō),最主要的工作實(shí)際就是三項(xiàng):

      1)讀者信息的基本情況及時(shí)錄入數(shù)據(jù)庫(kù);

      2)要將讀者查詢情況及時(shí)錄入數(shù)據(jù)庫(kù);

      3)對(duì)讀者操作情況進(jìn)行匯總。

      整體數(shù)據(jù)流:管理員通過(guò)密碼進(jìn)入系統(tǒng),分別對(duì)上述幾大功能逐一實(shí)現(xiàn)。

      在數(shù)據(jù)關(guān)系簡(jiǎn)單的情況下對(duì)數(shù)據(jù)處理,可以在將數(shù)據(jù)庫(kù)設(shè)計(jì)好之后直接設(shè)計(jì)程序。但是按正規(guī)的數(shù)據(jù)庫(kù)管理系統(tǒng)的設(shè)計(jì)程序,無(wú)論要處理的數(shù)據(jù)關(guān)系復(fù)雜與否都應(yīng)在做程序設(shè)計(jì)之前做好數(shù)據(jù)的流程分析。

      2.管理窗體

      創(chuàng)建該窗體,根據(jù)相關(guān)操作可以完成個(gè)人信息、圖書(shū)信息、管理操作、系統(tǒng)設(shè)置等功能實(shí)現(xiàn),在圖書(shū)信息里可以進(jìn)行圖書(shū)查詢、圖書(shū)借閱、圖書(shū)歸還、圖書(shū)續(xù)借等功能。

      總結(jié):圖書(shū)管理系統(tǒng)可以有效的省去很多的認(rèn)為登記錯(cuò)誤,并且能夠節(jié)省廣大的師生寶貴時(shí)間。另一方面,圖書(shū)

      館里系統(tǒng)具有界面清晰,操作方便,功能少而使用,實(shí)現(xiàn)圖書(shū)館工作的自動(dòng)化,減少手工勞動(dòng)量帶來(lái)的數(shù)據(jù)遺漏,誤報(bào)等人為因素,提高工作效率,也增強(qiáng)系統(tǒng)的通用性。但是完善的系統(tǒng)也會(huì)有所弊處,有計(jì)算機(jī)操控的系統(tǒng),一旦系統(tǒng)出現(xiàn)問(wèn)題,整個(gè)圖書(shū)館的借閱系統(tǒng)也會(huì)跟著癱瘓,帶來(lái)不便。所以,也要經(jīng)常的去維護(hù)系統(tǒng),這樣才能給我們提供一個(gè)安全的信息處理方法。

      管理信息系統(tǒng)創(chuàng)建,首先數(shù)據(jù)庫(kù)在一個(gè)管理系統(tǒng)中占有非常重要的地位,數(shù)據(jù)庫(kù)設(shè)計(jì)的好壞將直接對(duì)應(yīng)用系

      統(tǒng)的效率以及實(shí)現(xiàn)的效果產(chǎn)生影響。合理的數(shù)據(jù)庫(kù)結(jié)構(gòu)設(shè)計(jì)可以提高數(shù)據(jù)存儲(chǔ)的效率,以確保數(shù)據(jù)的完整性和一致性。設(shè)計(jì)數(shù)據(jù)庫(kù)系統(tǒng)時(shí)應(yīng)該首先充分了解用戶各個(gè)方面的需求,包括現(xiàn)有的以及將來(lái)可能增加的需求。數(shù)據(jù)庫(kù)設(shè)計(jì)一般包括如下幾個(gè)步驟:數(shù)據(jù)庫(kù)需求分析;數(shù)據(jù)庫(kù)邏輯結(jié)構(gòu)設(shè)計(jì);數(shù)據(jù)庫(kù)概念結(jié)構(gòu)設(shè)計(jì);數(shù)據(jù)庫(kù)物理設(shè)計(jì)。設(shè)計(jì)中詳細(xì)的總結(jié)了該系統(tǒng)的系統(tǒng)設(shè)計(jì)部分,包括功能模塊設(shè)計(jì)、數(shù)據(jù)庫(kù)結(jié)構(gòu)設(shè)計(jì)等。系統(tǒng)設(shè)計(jì)為整個(gè)程序構(gòu)建了骨架,各個(gè)功能模塊實(shí)現(xiàn)各個(gè)細(xì)節(jié)部分。通過(guò)本次課程設(shè)計(jì)知道了各種數(shù)據(jù)之間的相互關(guān)系,并在操作中用適當(dāng)?shù)腟QL語(yǔ)句和存儲(chǔ)過(guò)程實(shí)現(xiàn)。本系統(tǒng)還實(shí)現(xiàn)了VB通過(guò)ODBC對(duì)SQL的數(shù)據(jù)庫(kù)快遞、高效訪問(wèn)和更新功能。

      通過(guò)這次課程設(shè)計(jì)懂得了理論與實(shí)際相結(jié)合是很重要的,只有理論知識(shí)是遠(yuǎn)遠(yuǎn)不夠的,只有把所學(xué)的理論知識(shí)與實(shí)踐相結(jié)合起來(lái),從理論中得出結(jié)論,才能真正為社會(huì)服務(wù),從而提高自己的實(shí)際動(dòng)手能力和獨(dú)立思考的能力。在設(shè)計(jì)的過(guò)程中遇到問(wèn)題,可以說(shuō)得是困難重重,難免會(huì)遇到過(guò)各種各樣的問(wèn)題,同時(shí)在設(shè)計(jì)的過(guò)程中發(fā)現(xiàn)了自己的不足之處,對(duì)以前所學(xué)過(guò)的知識(shí)理解得不夠深刻,掌握得不夠牢固,通過(guò)這次課程設(shè)計(jì)之后,一定把以前所學(xué)過(guò)的知識(shí)重新溫故。

      在程序設(shè)計(jì)與代碼編寫(xiě)階段我們遇到了很多的問(wèn)題,由于我們組中的人大部分都是第一次開(kāi)發(fā)數(shù)據(jù)庫(kù)系統(tǒng),所以對(duì)數(shù)據(jù)庫(kù)開(kāi)發(fā)的流程不熟息,而且在數(shù)據(jù)庫(kù)的與編程系統(tǒng)的連接方面也遇到了很多的問(wèn)題。

      下載c語(yǔ)言圖書(shū)管理系統(tǒng)word格式文檔
      下載c語(yǔ)言圖書(shū)管理系統(tǒng).doc
      將本文檔下載到自己電腦,方便修改和收藏,請(qǐng)勿使用迅雷等下載。
      點(diǎn)此處下載文檔

      文檔為doc格式


      聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn)自行上傳,本網(wǎng)站不擁有所有權(quán),未作人工編輯處理,也不承擔(dān)相關(guān)法律責(zé)任。如果您發(fā)現(xiàn)有涉嫌版權(quán)的內(nèi)容,歡迎發(fā)送郵件至:645879355@qq.com 進(jìn)行舉報(bào),并提供相關(guān)證據(jù),工作人員會(huì)在5個(gè)工作日內(nèi)聯(lián)系你,一經(jīng)查實(shí),本站將立刻刪除涉嫌侵權(quán)內(nèi)容。

      相關(guān)范文推薦

        圖書(shū)管理系統(tǒng)

        七個(gè)文件 1. book.txt存放書(shū)籍2.borrower.txt存放借閱信息3.chenwen.txt 存放開(kāi)始信息 4. mima.txt存放密碼 5.qianyan.txt前言 6.student.txt存放學(xué)生信息7. yuyue.txt......

        圖書(shū)管理系統(tǒng)

        經(jīng)過(guò)大學(xué)四年理論課程的學(xué)習(xí),以及校內(nèi)校外的實(shí)踐,極大的豐富了自身的理論基礎(chǔ),并且也具備了一些處理簡(jiǎn)單問(wèn)題的能力,但即將踏上社會(huì)的我深知這還遠(yuǎn)遠(yuǎn)不夠,因此我利用了畢業(yè)設(shè)計(jì)的......

        圖書(shū)管理系統(tǒng)說(shuō)明

        圖書(shū)管理系統(tǒng)設(shè)計(jì)說(shuō)明書(shū)(上) 2009-02-12 18:10閱讀:3,614 摘 要: 介紹了信息中心圖書(shū)管理系統(tǒng)數(shù)據(jù)庫(kù)的設(shè)計(jì)。該系統(tǒng)是運(yùn)行在學(xué)校內(nèi)的圖書(shū)管理系統(tǒng),實(shí)現(xiàn)了圖書(shū)資料的計(jì)算機(jī)管理和......

        VB圖書(shū)管理系統(tǒng)

        圖書(shū)管理系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn) 目錄 一、序言····························································......

        智能圖書(shū)管理系統(tǒng)

        目錄 1.采訪管理子系統(tǒng) ............................................................................................................ 3 2.編目管理子系統(tǒng) ................

        圖書(shū)管理系統(tǒng)答案

        圖書(shū)管理系統(tǒng)答案 1.B2.D3.D4.C5.C6.A7.B8.A9.A10.B11.B12.B13.C 14.B15.D 16.C 17.B 18.D 19.C 20.C 21.A 22.C 23.A 24.B 25.A 26.B 27.B 28.B 29.D 30.A 31.A 32.B 33.A 3......

        圖書(shū)管理系統(tǒng)實(shí)驗(yàn)范文

        小型圖書(shū)管理系統(tǒng) 試驗(yàn)?zāi)康?采用C/S模式完成一個(gè)小型的圖書(shū)管理系統(tǒng);完成需求分析所有流程。 問(wèn)題及算法描述 完成一個(gè)小型圖書(shū)管理系統(tǒng),功能要求如下: 1) 能夠通過(guò)書(shū)籍基本信......

        圖書(shū)管理系統(tǒng)心得

        為期兩個(gè)星期的c#圖書(shū)管理系統(tǒng)實(shí)習(xí)終于結(jié)束了,總算松了一口氣,在這短短的兩周時(shí)間內(nèi)承受了很大的壓力現(xiàn)在終于能夠得到“釋放”了,感覺(jué)到很輕松?;仡欉@兩周所做過(guò)的工作和努力......