当前位置:首页 > 代码 > 正文

图书馆管理系统查询代码(图书馆网站代码)

admin 发布:2022-12-19 20:05 89


今天给各位分享图书馆管理系统查询代码的知识,其中也会对图书馆网站代码进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

数据库图书管理系统代码

create database db

use db

create table 借阅等级信息(

借阅等级 int primary key,

最长借阅时间 int,

最大借阅数量 int,

)

insert into 借阅等级信息 values

(0, 30, 10),

(1, 60, 20),

(2, 90, 30),

(3, 120, 40)

create table 读者信息(

姓名 char(15) not null,

证件号 char(12) primary key,

借阅等级 int default 0,

累计借书 int default 0,

foreign key(借阅等级) references 借阅等级信息(借阅等级)

)

insert into 读者信息(姓名, 证件号, 借阅等级) values

('张三', '541607120165', 1),

('李四', '541707010185', 3),

('王五', '541707120165', 1),

('赵六', '541505980268', 2),

('孙七', '541407010169', 0),

('周八', '541307010489', 1)

create table 出版社信息(

出版社 varchar(20) primary key,

地址 varchar(25),

联系电话 char(7)

)

insert into 出版社信息 values

('清华大学出版社', '北京', '4979421'),

('晟威出版社', '天津', '5564130'),

('南海出版公司', '海南', '4984910'),

('上海文艺出版社', '上海', '6640239')

create table 图书信息(

索书号 char(15) primary key,

作者 char(15),

书名 char(15),

出版社 varchar(20),

出版时间 date,

foreign key(出版社)references 出版社信息(出版社)

)

insert into 图书信息 values

('b12987', '严蔚敏', '数据结构', '清华大学出版社', '2012-02-06'),

('b97894', '东野圭吾', '幻夜', '南海出版公司', '2004-08-02'),

('b16546', '吴玉华', '物理实验教程', '清华大学出版社', '2013-05-15'),

('b89490', '张雪峰', '考研指点', '晟威出版社', '2016-12-12'),

('b56400', '郏宗培', '纸上寻仙记', '上海文艺出版社', '2011-02-05')

create table 单本图书信息(

条码号 char(7) primary key check(len(条码号) = 7),

索书号 char(15),

馆藏地 varchar(40),

书刊状态 varchar(6) check(书刊状态 in ('可借', '借出', '非可借')),

历史借阅量 int default 0,

foreign key(索书号)references 图书信息(索书号)

)

insert into 单本图书信息(条码号, 索书号, 馆藏地, 书刊状态) values

('t987628', 'b97894', '三楼A8', '借出'),

('t594805', 'b97894', '二楼C7', '可借'),

('t984910', 'b89490', '五楼A2', '借出'),

('t940566', 'b12987', '负一楼D3', '借出')

create table 借阅信息(

借阅号 char(6) primary key,

借阅时间 date,

归还时间 date,

图书条码号 char(7),

借阅人证件号 char(12),

foreign key(图书条码号) references 单本图书信息(条码号),

foreign key(借阅人证件号) references 读者信息(证件号)

)

create table 评论信息(

评论号 char(8) primary key,

评分 numeric(2, 1),

内容 varchar(200),

评论时间 date,

评论者id char(12),

索书号 char(15),

foreign key(索书号)references 图书信息(索书号),

foreign key(评论者id)references 读者信息(证件号)

)

insert into 评论信息 values

('p12391', 8.9, '很有趣', '2015-06-24', '541707010185', 'b97894'),

('p98523', 7.8, '受益颇多', '2016-05-22', '541307010489', 'b89490'),

('p94606', 6.8, '完全看不懂orz', '2017-05-02', '541607120165', 'b12987')

create table 主题词信息(

ID char(8) primary key,

类别 char(15),

索书号 char(15),

foreign key(索书号)references 图书信息(索书号)

)

insert into 主题词信息 values

('z64400', '计算机', 'b12987'),

('z95410', '物理', 'b16546'),

('z98500', '考研', 'b89490'),

('z64165', '推理\悬疑', 'b97894'),

('z69850', '仙侠', 'b56400')

use db

go

create trigger trigger1

on 借阅信息

after insert

as

begin 

update 读者信息                                                 --更改读者累计借书量

set 累计借书 = 累计借书 + 1                                   

from 读者信息, inserted

where 读者信息.证件号 = inserted.借阅人证件号

update 单本图书信息                                             --更改图书状态

set 单本图书信息.书刊状态 = '借出'

from inserted, 单本图书信息

where inserted.图书条码号 = 单本图书信息.条码号

update 单本图书信息

set 历史借阅量 = 历史借阅量 + 1                                 --更改图书历史借阅量

from inserted, 单本图书信息

where inserted.图书条码号 = 单本图书信息.条码号

end

insert into 借阅信息 values

('j13488', '2018-05-01', '2018-08-01', 't987628', '541407010169')

insert into 借阅信息 values

('j14910', '2016-12-11', '2017-01-25', 't984910', '541607120165')

insert into 借阅信息 values

('j97890', '2018-05-14', '2018-06-14', 't940566', '541607120165')

go

create view view_1(图书条码, 借阅者姓名, 编号, 借阅时间, 应还时间)

as

select 图书条码号, 姓名, 证件号, 借阅时间, 归还时间

from 借阅信息, 读者信息

where 借阅信息.借阅人证件号 = 读者信息.证件号 and 归还时间 getdate()

go

create view view_2(图书条码, 历史总借阅量)

as

select 条码号, 历史借阅量

from 单本图书信息, 图书信息

where 单本图书信息.索书号 = 图书信息.索书号 and 书名 = '幻夜'

go

create view view_3(类别, 图书条码, 历史总借阅量)

as

select 类别, 条码号, 历史借阅量

from 单本图书信息, 图书信息, 主题词信息

where 主题词信息.索书号 = 图书信息.索书号 and 图书信息.索书号 = 单本图书信息.索书号 and 类别 = '考研'

go

create view view_4(读者编号, 条码, 图书名称, 应还日期)

as

select 借阅人证件号, 图书条码号, 书名, 归还时间

from 单本图书信息, 图书信息, 借阅信息

where 借阅信息.图书条码号 = 单本图书信息.条码号 and 单本图书信息.索书号 = 图书信息.索书号

and 归还时间 getdate() and 借阅人证件号 = '541607120165'

go

create view view_5(读者编号, 图书条码, 图书名称, 借阅日期, 归还日期)

as

select 借阅人证件号, 图书条码号, 书名, 借阅时间, 归还时间

from 单本图书信息, 图书信息, 借阅信息

where 借阅信息.图书条码号 = 单本图书信息.条码号 and 单本图书信息.索书号 = 图书信息.索书号

and 借阅人证件号 = '541607120165'

go

create view view_6(读者编号, 图书名称, 评论时间, 评论内容)

as

select 评论者id, 书名, 评论时间, 内容

from 借阅信息, 单本图书信息, 评论信息, 图书信息

where 借阅信息.图书条码号 = 单本图书信息.条码号 and 单本图书信息.索书号 = 评论信息.索书号

and 评论信息.索书号 = 图书信息.索书号 and 评论者id = '541607120165'

go

create view view_7(出版社名称, 图书名称, 出版时间)

as

select top 100 percent 出版社信息.出版社, 书名, 出版时间

from 出版社信息, 图书信息

where 出版社信息.出版社 = 图书信息.出版社

order by 出版时间 asc

--执行

select * from view_1

select * from view_2

select * from view_3

select * from view_4

select * from view_5

select * from view_6

select * from view_7 order by 出版时间 asc

扩展资料:

数据库模型:

对象模型

层次模型(轻量级数据访问协议)

网状模型(大型数据储存)

关系模型

面向对象模型

半结构化模型

平面模型(表格模型,一般在形式上是一个二维数组。如表格模型数据Excel)

架构

数据库的架构可以大致区分为三个概括层次:内层、概念层和外层。

内层:最接近实际存储体,亦即有关数据的实际存储方式。

外层:最接近用户,即有关个别用户观看数据的方式。

概念层:介于两者之间的间接层。

数据库索引

主条目:数据库索引

数据索引的观念由来已久,像是一本书前面几页都有目录,目录也算是索引的一种,只是它的分类较广,例如车牌、身份证字号、条码等,都是一个索引的号码,当我们看到号码时,可以从号码中看出其中的端倪,若是要找的人、车或物品,也只要提供相关的号码,即可迅速查到正确的人事物。

另外,索引跟字段有着相应的关系,索引即是由字段而来,其中字段有所谓的关键字段(Key Field),该字段具有唯一性,即其值不可重复,且不可为"空值(null)"。

例如:在合并数据时,索引便是扮演欲附加字段数据之指向性用途的角色。故此索引为不可重复性且不可为空。

数据库操作:事务

主条目:数据库事务

事务(transaction)是用户定义的一个数据库操作序列,这些操作要么全做,要么全不做,是一个不可分割的工作单位。

事务的并发性是指多个事务的并行操作轮流交叉运行,事务的并发可能会访问和存储不正确的数据,破坏交易的隔离性和数据库的一致性。

网状数据模型的数据结构 网状模型 满足下面两个条件的基本层次联系的集合为网状模型。 1. 允许一个以上的结点无双亲; 2. 一个结点可以有多于一个的双亲。

参考资料来源:百度百科——数据库

求c++写的图书馆管理系统代码

#include stdio.h

#include string.h

#include stdlib.h

//

#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;iMAXSIZE;i++)

{

boo[i].NowNum=0;

boo[i].TotNum=0;

boo[i].next=NULL;

}

}

void InitRe(lend Lin) //初始化借阅者信息

{

for(int i=0;iLIST_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;imidtotal;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;jtotal;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].NowNum0) //看现库存是否大于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;iRetotal;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;iRetotal;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;kRetotal;k++)

if(!Lin[k].next)

{

int j;

for(j=k;jRetotal;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;itotal;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;itotal;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;iRetotal;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;iRetotal;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");

}

int 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);

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;

}

}

}

急求图书馆管理系统代码java,c++,delphi,vb都可以

/*1、 系统初始化10种图书(图书名自定);

2、 显示所有图书列表(编号、名称和当前状态);

3、 显示图书借出状态(是否已经被借阅);

4、 操作者可以通过图书名称进行查询,并借阅;

5、 操作者也可以归还某本已经借阅的图书;

6、 对某本图书的借阅次数进行汇总求和;

7、 求出借阅次数最多和最少的图书;*/

#ifndef LIBRARY_H

#define LIBRARY_H

#includevector

#includestring

#includeiterator

#includeutility

#includeiostream

using std::cin;

using std::vector;

using std::iterator;

using std::string;

using std::pair;

using std::istream;

class Book{

public:

Book(istream i):ve(bo(i)){};//1、 系统初始化10种图书(图书名自定);

void list(size_t n) const//查询

{ pairstring,bool ir=ve[n+1];

std::cout"第"n"本书名"ir.first"状态"std::ends;

(ir.second==true)?std::cout"存在":std::cout"已借出"std::endl;

std::coutstd::endl;}//2、 显示图书列表(编号、名称和当前状态);

void list(string str) //查询并借阅

{

vectorpairstring,bool ::iterator itr=ve.begin();

vectorpairstring,int ::iterator it=pai.begin();

while(itr!=ve.end())

{if(itr-first==strit-first==str)br {std::cout"存在!请输入y/n确认是否借阅"std::ends;br char ch;cinch;br if(ch=='y')br {itr-second=false;br it-second=it-second++;br std::cout"已借阅"std::ends;}

}else{std::cout"不存在"std::ends;}

++itr;++it;

}

}

void rest(string str)

{vectorpairstring,bool ::iterator itr=ve.begin();br while(itr++!=ve.end())br {if(itr-first==stritr-second==false)br {itr-second=true;br std::cout"已归还"" ";}else{std::cout"不在"std::endl;}}}//5、 操作者也可以归还某本已经借阅的图书;

void sum(const string str)

{vectorpairstring,int ::iterator it=pai.begin();br int max=(++it)-second;br int min=(++it)-second;br string ma,mi;br while(it!=pai.end())br {br if(it-first==str)br {std::cout"借阅次数为"(it-second)std::ends;}

if(maxit-second)

{max=it-second;br ma=it-first;}

if(minit-second)

{min=it-second;br mi=it-first;}}

std::cout"借阅最多次de 图书"ma" "max"次"std::endl;

std::cout"借阅最少次de 图书"mi" "min"次"std::endl;}/*6、 对某本图书的借阅次数进行汇总求和;

7、 求出借阅次数最多和最少的图书;*/

private:

vectorpairstring,bool bo(istream);

vectorpairstring,bool ve;

vectorpairstring,int pai;

};

vectorpairstring,bool Book::bo(istream is)//创建 图书 及存在情况

{

int i=0;

std::string s;

std::vectorpairstring,bool v;

vectorpairstring,int pai;

while(iss)

{

v.push_back(make_pair(s,true));

pai.push_back(make_pair(s,0));

++i;

if(i==10)

break;

}

is.clear();

return v;

}

#endif

下面是 main

#includeiostream

#include"library.h"

using namespace std;

int main()

{

size_t x=5;

string str;

Book a(cin);//初始化

cin.clear();

a.list(x);//输入数字查询

cout"输入查询"endl;

cinstr;

a.list(str);//输入字符查询并借阅

//a.rest(string("sa"));//归还

//a.sum(string("sa"));//查询某本书的借阅次数并统计输出借阅最多和最少的书

return 0;

}

图书馆管理系统查询代码的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于图书馆网站代码、图书馆管理系统查询代码的信息别忘了在本站进行查找喔。

版权说明:如非注明,本站文章均为 AH站长 原创,转载请注明出处和附带本文链接;

本文地址:http://ahzz.com.cn/post/22081.html


取消回复欢迎 发表评论:

分享到

温馨提示

下载成功了么?或者链接失效了?

联系我们反馈

立即下载