
#include <stdioh>
#include <stringh>
#include <stdlibh>
//
#define MAXSIZE 100 //最大值定义为100
#define LIST_INIT_SIZE 100//图书证使用者最大值定义为100
//借书人的结构体
typedef struct Boro//借书行为
{
char BNum[20];//借书的书号
char RetDate[8];//归还日期
struct Boro next;
}Bor;
typedef struct LinkBook
{
Bor next;//该图书证的借书行为
char CNum[20];//证号
int Total;//借书的数量
}lend[LIST_INIT_SIZE];//借书人数组
//图书的结构体信息
typedef struct LNode
{
char CardNum[20];//图书证号
struct LNode next;
}LinkList; //借书人
typedef struct book
{//每种图书需要登记的内容包括书号ISBN、书名、作者、出版社、总库存量和现库存量。
char num[20];//书号
char name[20];//书名
char auth[20];//作者
char pub[20];//出版社
int TotNum;//总库存
int NowNum;//现库存
LinkList next;//借了该书的人
}ook[MAXSIZE];
//
int Retotal;//读者数量
int total; //定义外部变量书的种类数
//
//结构体初始化
void InitBo(ook &boo) //初始化图书信息
{
for(int i=0;i<MAXSIZE;i++)
{
boo[i]NowNum=0;
boo[i]TotNum=0;
boo[i]next=NULL;
}
}
void InitRe(lend &Lin) //初始化借阅者信息
{
for(int i=0;i<LIST_INIT_SIZE;i++)
Lin[i]next=NULL;
}
//
int mid=0;//外部函数mid,用来返回查找到的位置
bool BinarySearch(ook boo,char SearchNum[]) //二分法查找比较书号
{ //用bool函数,但由于函数不能有两个返回值,所以设置一个外部变量mid,用来返回查找到的位置
int low=0,high=total-1;
int found=0;
while(low<=high)
{
mid=(low+high)/2; //中间点
if(strcmp(boo[mid]num,SearchNum)==0) //书号相同
{
found=1;
return true;
}//查找成功
if(strcmp(boo[mid]num,SearchNum)!=0)//书号不同
high=mid-1;
else low=mid+1;
}
if(found==0)
return false; //查找失败
}
void Buy(ook &boo, char BuyNum[])
{//1、 采编入库:新购入一种书,如果该书在图书账目中已经存在,则将其库存量增加(包
//括总库存量和现库存量),如果该书不存在,则在图书账目中增加一种书,总库存量和现库存量均为1。
if(BinarySearch(boo,BuyNum)) //如果书库中有此书
{
boo[mid]TotNum++; //总库存加1
boo[mid]NowNum++; //现库存加1
printf("入库成功\n");
printf("已更改书库中该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。\n",boo[mid]num,boo[mid]name,boo[mid]auth,boo[mid]pub,boo[mid]TotNum,boo[mid]NowNum);
}
if(!BinarySearch(boo,BuyNum))
{
int i;
for(i=total;i>mid&&total;i--) //插在适合位置 保持有序
boo[i]=boo[i-1]; //空出插入位置
printf("该书在书库中不存在。设立新书目,请补全书的详细信息。\n");
strcpy(boo[i]num,BuyNum);
printf("该书购入的数量是:");
scanf(" %d",&boo[i]NowNum);
boo[i]TotNum=boo[i]NowNum;
printf("该书的名字是:");
scanf(" %s",&boo[i]name);
printf("该书的作者是:");
scanf(" %s",&boo[i]auth);
printf("该书的出版社是:");
scanf(" %s",&boo[i]pub);//补全信息
boo[i]next=NULL;
total++;//总量+1
printf("已增加该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。\n",boo[i]num,boo[i]name,boo[i]auth,boo[i]pub,boo[i]TotNum,boo[i]NowNum);
printf("入库成功\n");
}
}
void Delete(ook &boo,char DeleteNum[])
{//2、 清空库存:某一种书已无保留价值,将它从图书账目中注销。
if(BinarySearch(boo,DeleteNum)==false||total==0) //如果无此书
printf("书库中没有该书\n");
if(BinarySearch(boo,DeleteNum))//若有
{
if(!boo[mid]next)
{
int j;
for( j=mid;j<total;j++)
boo[j]=boo[j+1];
strcpy(boo[j]num,boo[j+1]num);
strcpy(boo[j]name,boo[j+1]name);
strcpy(boo[j]auth,boo[j+1]auth);
strcpy(boo[j]pub,boo[j+1]pub);
boo[j]TotNum=boo[j+1]TotNum;
boo[j]NowNum=boo[j+1]NowNum;
printf("已成功删除该书\n");
}
else printf("该书有借阅者,无法删除。\n");
}
}
void Borrow(ook &boo,lend &Lin,char BorrowNum[],char CaNum[])
{//3、 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1,
//并登记借阅者的图书证号和归还期限。
Bor p,q;
LinkList m,n;
if(!BinarySearch(boo,BorrowNum)||total==0) //如果没有找到此书
printf("书库里没这书。\n");//如果有这书
if(BinarySearch(boo,BorrowNum)) //书库里有
{
if(boo[mid]NowNum>0) //看现库存是否大于0
{
boo[mid]NowNum--;//借出一本,少1
if(boo[mid]next==NULL) //若该书信息下显示该种书还没被人借过
{
m=(LinkList )malloc(sizeof(LNode));//分配
boo[mid]next=m;//该图书信息中的链表的第一个结点
strcpy(m->CardNum,CaNum);
m->next=NULL;//后一个结点为空
}
else //如果已经有人在借这书了
{
m=boo[mid]next;
while(m->next) //遍历到最后一个结点
m=m->next;
n=(LinkList )malloc(sizeof(LNode));//分配空间,增加1个结点
m->next=n;
strcpy(n->CardNum,CaNum);//记录证号
n->next=NULL;
}
int i=0;
for(i=0;i<Retotal;i++)//
{
if(!strcmp(Lin[i]CNum,CaNum))//如果已经有该图书证的信息
{
p=Lin[i]next;
while(p->next)p=p->next;//遍历到最后一个结点
q=(Bor )malloc(sizeof(Boro));//分配空间
p->next=q;
strcpy(q->BNum,BorrowNum); //记录书号
printf("输入归还日期:");
scanf("%s",&q->RetDate);
q->next=NULL;
printf("借阅成功\n");
break; //找到证了就跳出循环
}
}
if(i==Retotal)//如果没有这张证的信息
{
strcpy(Lin[i]CNum,CaNum); //记录证号
p=(Bor )malloc(sizeof(Boro)); //分配空间
Lin[i]next=p;
strcpy(p->BNum,BorrowNum);
printf("输入归还日期:");
scanf(" %s",&p->RetDate);
p->next=NULL;
Retotal++; //借阅证号信息总数加1
printf("借阅成功\n");
}
}
else printf("借阅失败该书现在库存为0\n");
}
}
void Return(ook &boo,lend &Lin,char ReturnNum[],char BorrowerNum[])
{//4、 归还:注销对借阅者的登记,改变该书的现存量。
Bor p,q;
LinkList m,n;
int flag=0;//设置一个参数
if(!BinarySearch(boo,ReturnNum)||!total) //没书
printf("书库中无此书\n");
if(BinarySearch(boo,ReturnNum)) //有书
{
m=boo[mid]next;
if(!strcmp(m->CardNum,BorrowerNum)) //如果是第一个借的人还的
{
boo[mid]NowNum++; //现库存加1
boo[mid]next=m->next; //删除结点
free(m); //释放该结点的空间空间
}
else
{
while(m->next) //查找归还者的借阅者结点
{
if(!strcmp(m->next->CardNum,BorrowerNum)) //如果找到
{
n=m->next; //n为归还者的借阅结点
m->next=n->next; //m指向归还者的借阅结点的下一结点
free(n); //释放空间
boo[mid]NowNum++; //现库存加1
break;
}
m=m->next;
}
}
}
//在借阅者表里查找借阅者信息
for(int i=0;i<Retotal;i++)
{
if(!strcmp(Lin[i]CNum,BorrowerNum)) //如果找到借阅者
{
p=Lin[i]next;
if(!strcmp(p->BNum,ReturnNum)) //如果是归还的是借的第一本书
{
Lin[i]next=p->next; //指向下一借书结点
free(p); //释放结点空间
printf("成功归还该书\n");
flag=1;
break;
}
else //找不到
{
while(p->next) //找到归还书的借书结点
{
if(!strcmp(p->next->BNum,ReturnNum)) //如果找到
{
q=p->next; //q为归还书的借书结点
p->next=q->next; //p指向下一借书结点
free(q); //释放空间
printf("成功归还该书\n");
flag=1;
break;
}
p=p->next;
}
}
}
}
for(int k=0;k<Retotal;k++)
if(!Lin[k]next)
{
int j;
for(j=k;j<Retotal;j++)
Lin[j]=Lin[j+1]; //其后都往前移一位,覆盖掉当前信息
strcpy(Lin[j]CNum," "); //删除图书证号
Retotal--; //图书证数减1
} //删除当前状态下没借书的图书证的信息,节省空间
if(flag==0) printf("无该证信息\n");
}
//5、 查找:实现按三种查询条件之一查找:按书号查找、
//按书名查找、按作者查找。注:可不实现组合查找,即几个条件组合查找。
void SearchByNum(ook &boo,char SeaNum[])
{//BY NUM 根据书号查找
LinkList p;
p=boo[mid]next;
if(BinarySearch(boo,SeaNum)==false)printf("对不起,未找到您想查找的书。\n");//二分查找 没找到
else//找到了的话
{
{
printf("┏━━━━━━━┳━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━┳━━━━━┓\n");
printf("┃ 书号 ┃ 书名 ┃ 作者 ┃ 出版社 ┃ 现库存 ┃ 总库存 ┃\n");
printf("┣━━━━━━━╋━━━━━━━╋━━━━━━━━╋━━━━━━━━╋━━━━━╋━━━━━┫\n");
printf("┃%14s┃%14s┃%16s┃%16s┃%10d┃%10d┃\n",boo[mid]num,boo[mid]name,boo[mid]auth,boo[mid]pub,boo[mid]NowNum,boo[mid]TotNum);
printf("┗━━━━━━━┻━━━━━━━┻━━━━━━━━┻━━━━━━━━┻━━━━━┻━━━━━┛\n");
if(boo[mid]next!=NULL)
{
printf("┏━━━━━━━┓\n");
printf("┃ 已借该书的 ┃\n");
printf("┃ 图书证号 ┃\n");
while(p)
{
printf("┣━━━━━━━┫\n");
printf("┃%14s┃\n",p->CardNum);
p=p->next;
}
printf("┗━━━━━━━┛\n");
}
}
while(p)
{
printf(" %s ",p->CardNum);//在按书号查找的函数里也显示借了这本书的借阅者的证号
p=p->next;
}
printf(" \n");
}//显示查找的书籍的信息
}
void SearchByName(ook &boo)
{//BY NAME 根据书名查找
char SeaName[20];
printf("输入想查找的书的书名:\n");
scanf(" %s",&SeaName);
printf("找到符合该书名的书的详细信息如下:\n");
for(int i=0;i<total;i++)
{
if(strcmp(SeaName,boo[i]name)==0)//如果书名一样
{
printf("书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n",boo[i]num,boo[i]name,boo[i]auth,boo[i]pub,boo[i]TotNum,boo[i]NowNum);
}//显示符合信息的所有书籍的信息
}
}
void SearchByAuth(ook &boo)
{// BY AUTH 根据作者查找
char SeaAuth[20];
printf("输入想查找的书的作者:\n");
scanf(" %s",&SeaAuth);
printf("找到符合该作者的书的详细信息如下:\n");
for(int i=0;i<total;i++)
{
if(strcmp(SeaAuth,boo[i]auth)==0)//如果作者一样
{
printf("书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n",boo[i]num,boo[i]name,boo[i]auth,boo[i]pub,boo[i]TotNum,boo[i]NowNum);
}//显示符合信息的所有书籍的信息
}
}
//6、 查看:可查看某图书证号的借阅者借阅的全部图书,可查看全部超期未还的图书。
void ViewCard(ook &boo,lend &Lin)
{//查看某图书证号的借阅者借阅的全部图书
char Num[20];
printf("请输入您所想要查看的图书证号:\n");
scanf(" %s",&Num);
Bor p;
int qqq=0;
for(int i=0;i<Retotal;i++)
{
if(strcmp(Lin[i]CNum,Num)==0) //找到该证
{
printf("这个证借的书有:\n");
p=Lin[i]next;
while(p)
{
printf(" %s ",p->BNum); //书号
p=p->next;
}
printf("\n");
qqq=1;
break;
}
}
if(qqq==0)
printf("该证不存在\n");
}
void ViewBook(ook &boo,lend &Lin)
{//查看全部超期未还的图书
char date[8];
Bor p;
printf("请输入日期(请按格式20060605输入):\n");
scanf(" %s",&date);
printf("所有超期未还的书有:\n");
for(int i=0;i<Retotal;i++)
{
p=Lin[i]next;
while(p)//当p不空时
{
if(strcmp(p->RetDate,date)<0) //超过日期
{
printf("书号为 %s 证号为 %s 应归还日期为 %s \n",p->BNum,Lin[i]CNum,p->RetDate);
}//显示所有超期未还的书的信息
p=p->next;
}
}
}
void Menu() //菜单
{
printf("┏—————————————————M E N U————————————————┓\n");
printf("│ │\n");
printf("│ 1 采编入库:新购入一种书,如果该书在图书账目中已经存在, │\n");
printf("│ 则将其库存量增加(包括总库存量和现库存量)。 │\n");
printf("│ 如果该书不存在,则在图书账目中增加一种书, │\n");
printf("│ 总库存量和现库存量均为输入的数字。 │\n");
printf("│ 2 清空库存:某一种书已无保留价值,将它从图书账目中注销。 │\n");
printf("│ 3 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1, │\n");
printf("│ 并登记借阅者的图书证号和归还期限。 │\n");
printf("│ 4 归还:注销对借阅者的登记,改变该书的现存量。 │\n");
printf("│ 5 按书号查找。 │\n");
printf("│ 6 按书名查找。 │\n");
printf("│ 7 按作者查找。 │\n");
printf("│ 8 查看某图书证号的借阅者借阅的全部图书。 │\n");
printf("│ 9 查看全部超期未还的图书。 │\n");
printf("│ 0 退出图书管理系统。 │\n");
printf("│ │\n");
printf("┗—————————————请 选 择 你 需 要 的 *** 作————————————┛\n");
}
void main()
{
ook Bo;
lend Lin;
char BNum[20];
char CNum[20];
printf("-----------------------欢 迎 进 入 图 书 管 理 系 统!---------------------------\n\n");
int choice=10;
int SearchCho=10,ViewCho=10;
while(choice!=0)
{
Menu();//显示菜单
scanf(" %d",&choice);
switch(choice)
{
case 1://采编入库
printf("请输入入库的书的书号:");
scanf(" %s",BNum);
Buy(Bo,BNum);
break;
case 2://清空库存
printf("请输入想要清除的书的书号:");
scanf(" %s",BNum);
Delete(Bo,BNum);
break;
case 3://借阅
printf("请输入想要借阅的书的书号:\n");
scanf(" %s",&BNum);
printf("请输入图书证号:");
scanf(" %s",&CNum);
Borrow(Bo,Lin,BNum,CNum);
break;
case 4://归还
printf("请输入想要归还的书的书号:\n");
scanf(" %s",&BNum);
printf("请输入图书证号:");
scanf(" %s",&CNum);
Return(Bo,Lin,BNum,CNum);
break;
case 5://查找//根据书号查找
printf("请输入书号:");//输入书号查找
scanf(" %s",&BNum);
SearchByNum(Bo,BNum);
break;
case 6://根据书名查找
SearchByName(Bo);
break;
case 7://根据作者查找
SearchByAuth(Bo);
break;
case 8://查看某图书证所借的所有书
ViewCard(Bo,Lin);
break;
case 9: //查看全部超期未还的书
ViewBook(Bo,Lin);
break;
case 0://退出系统
exit(0);break;
default:printf("输入错误!\n");exit(0);break;
}
}
}
摘 要:图书馆是集搜集、整理、收藏科学管理文献资料于一体的,以便广大读者使用借阅的的一种重要的机构。论文主要论述了当前图书馆管理系统主流产品的发展现状,分析了Web20和Library20等新理念对图书管理系统带来的新变化和新影响。总结了图书管理系统现存的一些问题,论述了图书管理系统发展趋势。
关键词:图书管理系统;Library20;云计算;发展趋势
随着科学技术的不断进步和发展,人类进入了信息社会,图书馆作为保存信息,储备资源的重要载体,发挥着越来越重要的作用,如何保护管理和应用自己的图书资源是一个国家信息化水平的重要体现。进入21世纪以来,图书馆开始实施自动化管理系统,为图书馆资源实现信息化和数字化方向的发展起到一定的引导和定位作用,并对图书馆业务的开展和读者服务工作的质量和效率产生直接而重大的影响。文章对图书管理系统现状进行了分析,对其存在的问题进行了研究,介绍了Web20等理念,在分析和研究图书馆管理系统发展现状的基础上,对图书馆管理系统的发展趋势做出了一定的预测。
一、图书管理系统当下的生存状况
1、国内图书管理系统当下的生存状况
(1)我国目前图书馆管理系统自动化总体上是不平衡的,主要体现在两方面一是高校图书馆与公共图书馆、其它类型图书馆管理系统发展的不平衡,一般来说,高校图书馆在自动化程度、服务的质量以及图书馆本身的先进设备等方面都优于其它类型图书馆,高校图书馆起到了“领头羊”的作用。另一方面,在同一系统内,图书馆自动化建设也是不平衡的,高校和科研系统图书馆的管理系统自动化建设主要集中在一些重点大学的重点学科单位,而在一些相对落后的城市和大中专院校的图书管理系统自动化方面尚处于初级阶段。
(2)图书馆管理系统在自动化方面还处于初级阶段,虽然自进入90年代中期以来,网络的覆盖面在逐渐的延伸,很多网络中心服务的质量和水平在逐步的提升,但总体距国际水平尚有很大的距离,其自动化水平还处于初级阶段。
(3)图书系统在自动化管理方面整体水平不高,很多图书馆的自动化建设还处于初级阶段,把图书馆内部业务作为处理的核心,仍然采用传统的图书馆业务流程来进行,自动化管理的水平整体不高,服务水平和质量普遍较低,尝试采用虚拟咨询台或呼叫中心,给客户提供咨询服务的图书馆寥寥无几,整体水平有待提高。
2、目前国外的图书管理系统的发展现状
目前国外很多公司都采用Ex libris 的Aleph500的系统,它是Ex libris公司的下一代数字图书馆系统的核心产,它提供给图书馆和读者的开放标准具有非常强的灵活性,该系统功能强大,而且具有信息查询、联合编目、馆际互借、资源共享的功能和设备。当然国外图书管理还采用了Horizon系统、Unicorn系统等,这些系统的功能和服务同样也非常完善和先进。
二、当前图书管理系统在发展的过程存在的问题
1、图书馆文献资源和信息服务需要加强融合
自新世纪以来,数字图书馆以令人惊异的速度迅猛发展着,很多图书馆数字资源的购置费用甚至已经远远高于纸本资源的购置费用,数字资源在图书馆信息资源中占据着重要地位,数字图书馆很明显的特征就是它的合作、共享管理等特征,图书管理系统的一大招牌和亮点就是数字信息图书馆提供的网络服务,但是,现实的状况是,要实现图书馆的资源整合和服务一体化的进程还是遇到了很多的困难,比如,数字资源和纸本资源之间的的相互孤立,传统文献和网络信息服务之间巨大的差距,都对这一进程的实现产生了非常不利的影响。数字图书馆还需要将几个大型原始数据库的大量重要数据进行整合,处理,使这些数据更有条理和清晰化,最终的结果是使各个工作环节都能有效,流畅的联结起来,增加工作的方便性和快捷性,现在很多高校图书馆采用了Opac检索系统对馆藏纸本资源和数字资源进行了整合。例如,重庆大学图书馆Opac系统在展示图书检索结果的同时,显示电子图书的在线阅读链接和书后光盘的下载链接,显示期刊检索结果的同时显示电子期刊导航的链接。
2、图书馆的业务处理和管理工作不能很好的做好配合、衔接的工作
现在很多图书馆的管理仍然放在纸质的图书和文献上,对数字图书业务缺乏相应的重视,不能提供有效的网络信息服务,仍然停留在以纸质图书为主的自动化管理系统,这在一定程度上对数字图书管理工作造成了困难,阻碍的了数字图书网络信息服务的完善和使用,只有图书馆的图书业务处理和网络信息服务工作有效的实现良好配合,才能更好的解决图书馆管理系统所遇到的难题。
3、各种信息之间相互孤立,不能有效的实现整合
伴随着读者对图书馆数字管理系统提出的要求越来越多,图书馆的发展也是非常迅速,各种新业务的不断出现和增多,这一方面对图书管理者提出了更高的要求,另一方面对现有的图书馆管理系统也是一个严峻的考验,图书管理系统很难满足集成全部业务工作的要求,这就导致了独立系统的增多,各个信息之间相互分离的状况严重,即所谓的信息孤岛现象,这种状况的出现容易使读者迷惑,也不利于图书馆管理工作的顺利进行,对后续资源的整理和服务带来了一定的困难。
4、难以体现图书馆的管理思路
现在的很多图书馆不能把以读者为中心的服务理念贯彻实施,无法体现图书馆的管理思路和理念,造成这种状况原因有很多,比如,没有清晰的服务理念等,但主要还是因为现有系统无法评价图书馆的运行和服务开展情况,无法掌握读者的关注点和图书馆管理人员的工作情况,难以给馆长提供有效的决策支持。重庆大学图书馆所采用的Adlib20系统可以有效的弥补这一缺憾,它可以提供图书馆运行状态功能,系统利用晚上的空闲时间自动统计一天业务运行状况,并将业务数据进行自动处理,实现数据静态化,避免下次查询占用系统资源,并可组合查询一段时间的运行统计数据,使管理者可以随时查询到图书馆的运行服务状态,更好的改进和提高图书馆管理的质量和效率。
三、图书管理系统前景展望
需求分析,概念结构设计,逻辑结构设计,物理结构设计。已开发一个图书馆系统为例分析数据库设计有需求分析,概念结构设计,逻辑结构设计,物理结构设计基本的步骤。数据库系统(databasesystems),是由数据库及其管理软件组成的系统。它是为适应数据处理的需要而发展起来的一种较为理想的数据处理的核心机构。
以上就是关于如何用C++建立一个图书馆数据库管理系统全部的内容,包括:如何用C++建立一个图书馆数据库管理系统、图书馆管理系统数据库【浅谈图书馆管理系统的发展趋势】、已开发一个图书馆系统为例分析数据库设计有哪些基本的步骤等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)