pb图书管理系统_第1页
pb图书管理系统_第2页
pb图书管理系统_第3页
pb图书管理系统_第4页
pb图书管理系统_第5页
已阅读5页,还剩12页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、图书管理系统摘 要随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。管理信息系统是一个不断发展的新型学科,企业要生存要发展,要高效率地把企业活动有机地组织起来,就必须加强企业管理,即加强对企业内部的各种资源(人、财、物等)的有效管理,建立与自身特点相适应的管理信息系统。 本文介绍了在PowerBuider环境下采用“自上而下地总体规划,自下而上地应用开发”的策略开发一个管理信息系统的过程。通过分析传统的人工管理图书馆的不足,创建了一套行之有效的计算机管理图书馆的方案。文章详细介绍了图书管理信息系统的系统分析部分,包括可行性分析、组织机构分析、管理职能分析、业务流

2、程分析、数据流程分析、数据字典、处理描述等等;系统设计部分主要介绍了系统功能设计和数据库设计;系统实现部分列出了几个主要的程序框图,并附带了一些主要的窗口和程序。本系统界面友好,操作简单,比较实用。1简介随着人类社会的发展,人类对知识的需求也不断地增长。在这种形势下,书籍就渐渐地成为人们获取并增长知识的主要途径,而图书馆就自然而然地在人们的生活中占据了一定的位置,如何科学地管理图书馆不但关系到读者求知的方便程度,也关系到图书馆的发展,因此,开发一套完善的图书馆管理系统就必不可少了。管理信息系统(简称MIS)是介于信息论,经济管理理论,统计学与运筹学及计算机科学之间的一门边缘性,综合性,系统性的

3、交叉科学,它是随着管理科学,信息技术,计算机技术等的发展而产生和发展起来的。图书馆管理系统是典型的信息管理系统,其开发主要包括后台数据库的建立和维护以及前端的应用程序的开发两个方面。对于前者要求建立数据的一致性和完整性,对于后者则要求应用程序功能的完备,易用等的特点。基于上述考虑本系统主要利用PowerBuilder 9.0作前端的应用开发工具 ,利用是SQL Server2005 作为后台的数据库,利用WINDOWS作为系统平台开发的图书管理系统。另外本图书馆管理系统利用软件工程化思想和方法,总体上是采用结构化生命法进行系统分析和设计的,而系统实现等步骤则采用了原型法和面对对象的方法。2需求

4、分析阶段2.1 引言进行系统设计,首先要对系统的现状进行分析。根据系统的目标、需求和功能,制定和选择一个较好的系统方案,从而达到一个合理的优化系统。每个学校都有图书馆,最初由于图书数量和种类较少,人工手动管理比较方便和灵活。随着社会的发展,图书的数量和种类越来越多,人工手动管理会降低工作的效率,希望建立一个图书管理系统,是为了解决人工手动管理图书信息在实践的问题,从而达到系统化、规范化、标准化的水平。该系统的建立不但给管理者带来了方便,也节省了工作时间从而提高了工作效率。需求分析是在于要弄清用户对开发的数据库应用系统的确切要求。数据库设计的第一步是明确数据库的目的和如何使用,也就是说需要从数据

5、库中得到哪些信息。明确目的之后,就可以确定您需要保存哪些主题的信息(表),以及每个主题需要保存哪些信息(表中字段)。在构造系统时,首先从需求出发构造数据库表,然后再由数据库表结合需求划分系统功能模块。这样,就把一个大的系统分解成了几个小系统。这里把系统的层次划分为了四个部分:图书维护,人员信息管理,图书借阅管理,信息查询。能够实现以下功能: 进行新书入库、现有图书信息修改以及删除; 能够实现对读者基本信息的查询和编辑管理;能够进行借阅信息的查询功能; 能够进行简单的密码修改;2.2处理功能及要求(1)能够存储一定数量的图书信息,并方便有效的进行相应的书籍数据操作和管理,这主要包括:1) 图书信

6、息的录入、删除及修改。2) 图书信息的多关键字检索查询。3) 图书的出借、返还。(2)能够对一定数量的读者、管理员进行相应的信息存储与管理,这其中包括:1) 读者信息的登记、删除及修改。 2) 管理员信息的增加、删除及修改。 3) 读者资料查询及密码修改。(3)能够提供一定的安全机制,提供数据信息授权访问,防止随意删改、查询。2.3 E-R图2.3.1用户信息E-R图 用户信息权限 用户ID密码用户名2.3.2图书信息E-R图书名图书ID作者价格图书信息 出版日期条形码出版社2.3.3图书借还E-R图借还信息是否归还读者ID图书ID还书日期借书日期2.3.4读者信息E-R图地址读者信息读者ID

7、电话姓名出生日期性别2.4系统功能图 图书管理系统图书维护子系统人员资源管理子系统借还服务子系统查询服务子系统修改馆藏图书删除无效用户归还服务修改用户信息图书查询服务个人信息查询借阅服务添加新用户及管理员删除损毁图书添加新到图书3数据字典表3-1 图书表boot_t字段名字段含义数据类型是否为空b_id图书IDVarchar(20)否b_name书名Varchar(60)否auther作者Varchar(20)否publish_company出版社Varchar(60)是publish_day出版日期datetime是isbn条形码Varchar(60)是price价格Numeric(9,2)

8、是表3-2 借还图书记录表jiehuant字段名字段含义数据类型是否为空m_id读者IDVarchar(20)否b_id图书IDVarchar(20)否jiedate借书日期datetime是huandate还书日期datetime是remark是否归还Varchar(60)否表3-3 读者表membert字段名字段含义数据类型是否为空m_id读者IDVarchar(20)否m_name姓名Varchar(60)是sex性别Varchar(2)是birthday出生日期Datetime是phone电话Varchar(60)是address地址Varchar(50) 是表3-4 用户表peopl

9、e字段名字段含义数据类型是否为空user_id用户IDVarchar(50)否user_name用户名Varchar(50)是password密码Varchar(50)是admin权限Varchar(50)否4系统模块 4.1登陆界面设计图4-1登陆界面4.1.1登录按钮clicked()事件string user ,pass ,temp1,temp2,temp3user = sle_1.textb=user /全局变量中定义的if len(user) = 0 or isnull(user) = true thenmessagebox("提示","用户名不能为空!

10、")returnend ifselect user_id into :temp1 from people where user_id = :userusing sqlca;if sqlca.sqlcode <> 0 thenmessagebox("提示","用户名不存在!")returnend ifpass = sle_2.textselect password into :temp2 from people where user_id = :userusing sqlca;if pass <> temp2 thenme

11、ssagebox("提示","口令错误!")returnend ifselect admin into :temp3 from people where user_id = :user using sqlca;a=temp3open(w_main)close(w_1)4.2主界面设计图4-3主界面4.2.1主界面的open()事件if a = '1' thenw_main.cb_1.enabled=truew_main.cb_2.enabled=truew_main.cb_3.enabled=truew_main.cb_4.enabled

12、=truew_main.cb_5.enabled=truew_main.cb_7.enabled=truew_main.cb_6.enabled=trueelsew_main.cb_1.enabled=falsew_main.cb_2.enabled=falsew_main.cb_7.enabled=falseend if4.3密码修改设计4-3密码修改界面4.3.1确认按钮clicked()事件string user_id,passint rselect user_id ,password into :b,:pass from people where password=:sle_1.tex

13、t and user_id=:busing sqlca;if sqlca.sqlcode =0 thenif sle_2.text=sle_3.text thenupdate people set password=:sle_2.text where user_id=:b;commit using sqlca;messagebox("提示","密码修改成功!")open(w_main)close(w_7)returnelse r=messagebox("提示","新密码有误!",question!,yesno!,2

14、)if r = 1 then sle_1.text="" sle_2.text="" sle_3.text=""else open(w_main) close(w_7) return end if end if else r=messagebox("提示","旧密码有误!",question!,yesno!,2) if r = 1 then sle_1.text="" sle_2.text="" sle_3.text="" elseop

15、en(w_main) close(w_7) return end if end if4.4用户注册设计4-4用户注册界面4.4.1确定按钮clicked()事件string ls_id,ls_name,ls_password,ls_admin,ls_templs_id=sle_1.textls_name=sle_2.textls_password=sle_3.textls_admin=ddlb_1.textstring aaif sle_1.text=''or sle_2.text=''or sle_3.text=''or ddlb_1.text

16、=''thenmessagebox("提示!","用户编号,用户名,密码或角色不能为空!")returnend if select user_id into :aa from people where user_id=:sle_1.textusing sqlca;if sqlca.sqlcode=0 thenmessagebox("提示!","此用户已存在!")else if ls_admin='2' then insert into people values(:ls_id,:ls

17、_name,:ls_password,:ls_admin); messagebox("提示!","创建新用户成功!") open(w_main) close(w_5)else if ls_admin='1'theninsert into peoplevalues(:ls_id,:ls_name,:ls_password,:ls_admin);messagebox("提示!","创建新管理用户成功!")open(w_main) close(w_5) else end ifend ifend ifcom

18、mit;4.5用户注销界面设计4-5用户注销界面4.5.1查询按钮clicked()事件string sinteger ii=tab_1.tabpage_2.ddlb_2.SelectItem(ddlb_2.text, 0)choose case icase 1 s="user_id"case 2s="user_name"end chooseif s<>"" then s=s+"= "+ "'"+tab_1.tabpage_2.sle_4.text+"'&q

19、uot;end iftab_1.tabpage_2.dw_1.setfilter(s)tab_1.tabpage_2.dw_1.filter()4.5.2删除按钮clicked()事件string sinteger ii=tab_1.tabpage_2.ddlb_2.SelectItem(ddlb_2.text, 0)choose case icase 1 s="user_id"case 2s="user_name"end chooseif s<>"" then s=s+"= "+ "'"+tab_1.tabpage_2.sle_4.text+"'"end iftab_1.tabpage_2.dw_1.setfilter(s)tab_1.tabpage_2.dw_1.filter()5测试总结通过这次的数据库课程设计,独立完成了图书销售管理系统的设计,从这次的系统设计中我领略了一下几点:1)数据库应用系统的开发设计是一个规范化的过程,需要遵循以定的方式方法与开发设计步骤;2)开发一个数据

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论