简单图书管理系统设计

2022-05-16 版权声明 我要投稿

第1篇:简单图书管理系统设计

一种设计简单的数字调频同步激励器远程监测系统

摘要:随着互联网的日益普及,广电设备智能化、数字化的程度不断提高,基于Internet的广电机房设备远程监控系统逐渐成为发展趋势。文章给出了基于嵌入式WEB技术的GDSM-FM-06 调频同步激励器远程监测系统设计方案。

关键词:嵌入式WEB技术;B/S架构;远程监测;调频同步激励器

Design a simple remote Monitoring system for digital synchronous frequency-modulation inciter

ZHANGHai-qiong

(Anhui Radio Film and Television Institute of Vocational Technology, Hefei 230022, China )

Key words:embedded Web technology; b/s architecture; remote monitoring; digital synchronous frequency-modulation inciter

1 引言

机房设备监控系统,实质是远程数据采集控制系统在行业中的狭义应用。广电机房设备是广电网络的重要组成部分,做好广电机房设备的远程监测与控制工作,其意义不仅仅在于能够监测广电机房设备的工作状态,更重要的是提高播出系统的可靠性与稳定性,使机房设备维护从定期维护转为状态维护,保证广播电视安全稳定播出。为实现广电机房“无人值班,有人留守”的现代化管理模式提供了技术保证。

GDSM-FM-06立体声调频同步激励器是一款精密的全数字调频同步激励器。它采用先进的数字信号处理(DSP)和直接数字频率合成(DDS)等技术实现高稳定度的射频输出及载波同步。调频激励器是调频发射机的信息处理核心,直接决定发射机性能的优劣,同时它还部分承担了发射机故障处理及报警的责任。因此对激励器进行远程监测就具有重要的意义。

根据嵌入式技术的发展和广电机房设备的现状,研制一种将微处理器、存储器、网络芯片、嵌入式网页服务器等子系统集成一体,具有智能化、网络化、模块化、可靠性高、成本低廉以及维护简单等特点的基于嵌入式WEB的数字调频同步激励器远程监测系统势在必行。

2 基于嵌入式WEB的数字调频同步激励器远程监测系统的设计

2.1 系统原理简介

嵌入式系统是以应用为中心,以计算机技术为基础,以微处理器或微控制器为核心的专用计算机系统。嵌入式系统与Internet技术相结合,采用B/S(浏览器/服务器)架构应用方式形成的嵌入式Web技术是近几年随着计算机网络的普及而发展起来的一项新兴技术。基于嵌入式Web技术的机房设备环境实时监控系统是指将嵌入式Web 服务器嵌入到机房设备和机房环境监控装置中,在相应的硬件平台和软件系统的支持下将机房设备参数和机房环境量的数据发送至互联网上共享,为Internet或局域网用户提供基于Web 的图形化管理接口,从而省去了专用客户端管理软件,实现对接入到网络中各种设备的统一管理。

基于嵌入式Web技术的数字调频同步激励器远程监测系统的核心是嵌入式Web服务器,嵌入式Web服务器由微处理器MCU和以太网接口控制器芯片组成的硬件平台和由数据采集程序、TCP/IP协议栈和HTTP服务器程序组成的软件系统相结合的体系来实现的。基于嵌入式Web技术数字调频同步激励器远程监测系统设计的总体思路是嵌入式Web服务器通过通信端口或现场总线与本地数字调频同步激励器直接相连,并将接收到的数据经过分析、处理后通过TCP/IP协议将其连接到以太网上。客户端监控主机则通过Web浏览器在远程实时地监测现场信号的动态变化,从而实现远程监测的目标。

基于嵌入式Web的数字调频同步激励器远程监测系统原理框图如图1所示。

2.2 系统硬件设计

基于嵌入式Web技术的数字调频同步激励器远程监测系统的硬件平台主要由嵌入式Web服务器和接口电路组成。

嵌入式Web服务器采用Silicon Laboratories公司的高速单片机C8051F120作为中央处理单元。C8051F系列单片机是集成的混合信号片上系统SOC(System on chip),具有与MCS-51内核及指令集完全兼容的微控制器,除了具有标准8051的数字外设部件之外,片内还集成了数据采集和控制系统中常用的模拟部件和其它数字外设及功能部件。网络协议转换器采用CP2200单芯片以太网控制器,CP2200是集成了IEEE 802.3以太网媒体访问控制器(MAC)、10Base-T物理层(PHY)和8KB非易失性FLASH存储器的单芯片以太网控制器。片内FLASH存储器可用于存储用户常数、Web服务器内容或作为通用非易失性存储器。FLASH存储器的最后6个存储单元已在出厂前被预先写入了一个唯一的48位MAC地址。CP2200采用精巧的5 × 5毫米封装,能在-40℃到+85℃工业级温度范围内正常工作。

根据GDSM-FM-06立体声调频同步激励器通信协议以及使用状况要求,考虑到一般调频发射机房都有数台调频同步激励器同时工作,因此在其监控系统设计中增加一个嵌入式串口扩展模块。嵌入式串口扩展模块采用成都国腾微电子有限公司生产的GM8125芯片。

GM8125可以将一个全双工的标准串口扩展成5个标准串口。该芯片工作在多通道模式下时,子串口能主动响应从机发送的数据,并由母串口发送给主机,同时返回子串口地址。该模式使每个从机的发送要求都能被及时地响应,即使所有从机同时有发送要求,数据也不会丢失,基本实现了主控单元和外设通讯的实时性。该芯片的外部控制少,应用灵活,编程使用简单,适用于大多数有串口扩展需求的系统。这就实现了一台嵌入式Web服务器同时监测5台调频同步激励器的功能。

2.3 系统软件设计

基于嵌入式Web技术的GDSM-FM-06立体声调频同步激励器远程监测系统软件架构采用浏览器/服务器(B/S)模式,客户端可使用Microsoft internet explorer浏览器,服务器采用基于CMX-MICRONET的TCP/IP协议栈实现HTTPWeb服务。远程测控功能通过CGI(通用网关接口)程序实现。即客户端通过HTTP协议发出请求,该请求到达Web服务器后执行相应的CGI程序采集数据并将结果发回客户。图像、声音及动画等多媒体数据的处理是通过嵌入在网页中的Java Applet程序来实现交互功能。

图1 数字调频同步激励器远程监测系统原理框图

图2 GDSM-FM-06 调频同步激励器远程监测系统界面

客户端的IE浏览器通过B/S 方式访问Web 服务器上的网页数据时,网页中Java Applet能够被传送到浏览器并且在浏览器所在的本地机上运行。系统通过Java Applet平衡了服务器端与浏览器端的负载状况,将一部分从前在服务器上工作分给了浏览器,降低了服务器的运行负荷。

2.4 系统实现功能

根据GDSM-FM-06 调频同步激励器监测要求,本系统主要实现了以下几个方面的监测功能:

实现了音频状态信息、功率放大器状态信息、调制状态信息、同步状态信息及系统信息监测共计22项指标的监测功能。

实现了“音频”、“秒脉冲”、“10MHz”、“内环”、“外环”、“射频”、“失锁”、“保护”、“反射”和“互锁”报警信息状态指示灯的动态显示功能。完成了“手动查询,自动报警”的设计要求。

GDSM-FM-06 调频同步激励器远程监测系统界面如图2所示。

该系统完全摆脱了传统监控模式在地点、空间和人数上的限制,监控人员可以灵活机动、随时随地通过现有的公共通信网络在本地PC上使用标准的IE浏览器作为接口直接访问嵌入在GDSM-FM-06 调频同步激励器上的Web服务器。最大限度的发挥了监控系统的可用性和灵活性。

3 结束语

嵌入式Web服务器的应用能降低监控系统维护成本,提高监控系统运行效率。针对广电机房设备与以太网间的通信互联,本文实现了嵌入式Web在GDSM-FM-06 调频同步激励器远程监测系统中的应用,它为我们管理、控制和监测各种各样广电机房设备提供了一个切实可行的途径。

参考文献:

[1] 潘琢金,施国君.编著.C8051FXXX高速SOC单片机原理及应用[M]. 北京:北京航空航天大学出版社,2002.

[2] 许海燕,付炎.编著.嵌入式系统技术与应用[M]. 北京:机械工业出版社,2002.

[3] 金勇华,曲俊生.编著.Java 网络高级编程[M]. 北京:人民邮电出版社,2001.

[4] 童长飞.编著.C8051F系列单片机开发与C语言编程[M]. 北京:北京航空航天大学出版社,2005.

作者:张海琼

第2篇:《简单结构的设计》教学策略研究

[摘 要]文章针对《简单结构的设计》这节课的特点,在教学策略方面进行了一些探索性实践研究,摸索出一套行之有效的教学策略。实践证明,这套教学策略可以有效提高学生学习的积极性,培养学生的创造性。

[关键词]通用技术;结构设计;教学策略

[

《简单结构的设计》这节课是通用技术《技术与设计2》第一章第3节的内容,讲解结构设计的理论和实操案例。在以往的教学中面临两个主要困境:①教师干讲理论部分的内容,学生觉得空洞抽象,枯燥乏味。②课本所给的实操案例“简易相片架”不能同时考查结构设计中稳定性和承重性两方面的内容,难以承载这一章最重要的两部分理论知识。如何激发学生的学习兴趣、培养学生学以致用的能力是教师要深思的问题。笔者针对课堂教学中存在的问题进行了一些探索创新,在实践中逐步完善,形成了一套行之有效的课堂教学策略,主要有以下几点。

一、教学策略

1.采用项目教学法

墨子说,士虽有学,而行为本焉。通用技术是注重动手实践的学科。传统的教学方法采用的是“教师讲解+学生做题”这种应试的模式,学生缺乏实践的机会,难以做到学以致用。笔者在实践中发现,将项目教学法作为这节课的主要教学方法更为合适。项目教学法是将知识点和教学目标恰到好处地融入一个个具体的项目中,学生通过亲手完成具体项目来解决实际问题,建构属于自己的知识体系。项目教学法让每个学生都能参与其中、相互合作、动手动脑,展示自己的才华、感受设计的魅力。

2.信息化学习

传统教室中没有互联网和制作工具,学生只能被动听老师讲解,没有主动求知的条件,更谈不上有动手的机会。笔者将授课地点由传统教室转到了计算机教室和通用技术实验室。学生的自主学习、方案构思、设计评价、作品发布都在计算机教室进行,教师向每个学生下发辅助学习包。学习包内含微课、课件、学案、素材等自学资料,学生可借助学习包和互联网资源完成理论学习和方案构思,具体制作环节则在通用技术实验室完成。整个学习过程中,教师并不直接讲授,而是为学生精心准备自学材料,引导学生组成学习小组互帮互助,利用各种数字化资源完成自主学习和设计制作。学生由被动地听变为主动地学,真正成为学习的主人。

3.项目案例的选择

(1)能充分涵盖结构设计这一章的主要知识点。(2)能充分激发学生兴趣,便于他们展示自己的创造能力。(3)难度要适中,学生通过自主学习和相互合作可以完成。

只有恰当的项目,才能既运用到课本上的知识点又能让学生发挥出他们的创造性。笔者通过多次实践,发现设计制作桌椅、书架、桥梁模型、房屋模型等项目是比较理想的选择。

二、典型案例

在这个项目中,教师全程不直接讲授,而是指导学生利用信息化手段完成自主学习和设计制作。将教师从繁重的讲解中解放出来,成为学生学习的指导者,充分调动起学生这个学习主体的积极性和主动性。

三、实践结果展示

1.学生作品展示

实施项目教学法后诞生了大量优秀的学生作品,以下是部分学生作品的展示,如图1。

2.问卷调查结果

笔者随机抽取本校8个班的学生進行了问卷调查,发放问卷450份,回收有效问卷420份,统计结果见图2、图3。

四、结论和反思

调查结果显示,大多数学生更加认可项目教学法+数字化学习的教学方式,认为这种注重实践和自主学习的教学方法更能有效提升能力和技术素养。新的教学策略在实践中受到学生的欢迎,不断涌现的优秀学生作品在带给教师惊喜的同时也在激励教师继续努力、探索前行。

[ 参 考 文 献 ]

张正德.美国信息技术的发展及其经济影响[M].武汉:武汉大学出版社,1995.

(责任编辑 黄 晓)

作者:王钰

第3篇:网络蜘蛛的简单设计与研究

【摘 要】:隨着互联网的发展,网络中的资源越来越多,人们在享受互联网带来的便利的同时,却面临着一个如何地从浩瀚的信息资源中快速、准确地找到用户所需要的信息的问题搜索引擎就是在这种背景下孕育而生,解决了这一个大问题。搜索引擎是指根据一定的策略、运用特定的计算机程序搜集互联网上的信息,在对信息进行组织和处理后,并将处理后的信息显示给用户,是为用户提供检索服务的系统。而在搜索引擎中最重要模块就是网页抓取模块—网络蜘蛛,本文从搜索引擎开始介绍,阐述了搜索引擎的原理以及发展现状,进而介绍了网络蜘蛛结构和其实现原理和策略,并对网络蜘蛛的关键部分进行了简单的设计。

【关键词】网络蜘蛛;搜索引擎

1 研究背景

互联网的飞速发展使得网络成为了人们获取信息的一个重要途径,而网络上的信息的飞速增长,给人们带来了前所未有的丰富的信息资源,却也产生了新的矛盾,即在给人们提供丰富信息的同时,也给人们带来巨大的挑战:由于网络上的信息种类繁多,人们很难找到真正有用的信息。因此,不得不花费大量的时间去搜索浏览自己需要的信息,搜索引擎随之成为了人们最普遍使用的信息检索的工具。

2 网络蜘蛛概述

2.1 网络蜘蛛在搜索引擎中的作用

作为搜索引擎的一部分,网络蜘蛛在搜索引擎中起着举足轻重的作用,它通过网页的链接地址来寻找网页,从网站某一个页面开始,读取网页的内容,找到在网页中的其它链接地址,然后通过这些链接地址寻找下一个网页,这样一直循环下去,直到把这个网站所有的网页都抓取完为止。在搜索引擎中主要是通过蜘蛛程序自动访问互联网,抓取网页并把网页收集起来。这是搜索引擎的基本原理之一。因此,网络蜘蛛的研究对搜索引擎的开发具有重要意义。

2.2网络蜘蛛访问策略

网络蜘蛛访问一个网站,需要从已知的入口页面开始。从这个页面通过链接分析,找到后续网页。在这个访问过程中主要有两种策略:广度优先和深度优先。广度优先是指网络蜘蛛会先抓取起始网页中链接的所有网页,然后再选择其中 的一个链接网页,继续抓取在此网页中链接的所有网页。深度优先是指网络蜘蛛会从起始页开始,一个链接一个链接跟踪下去,处理完这条线路之后再转入下一个起始页,继续跟踪链接。这个方法有个优点是网络蜘蛛在设计的时候比较容易。在本文中使用的策略是深度优先算法。

3 网络蜘蛛的设计与研究

3.1 网络蜘蛛的设计思想

开发和设计网络蜘蛛程序有两种思想可以选择:一种就是将程序设计为递归的程序;另一种就是将程序设计为非递归的程序。采用递归设计的程序思路清晰简单,但存在两个主要的问题:第一问题就是如果程序要运行很多次,被压入递归的堆栈会变得非常大,从而消耗大量内存;第二问题就是多线程技术与递归技术不能兼容。我们研究的高性能网络蜘蛛采用的是非递归程序设计思想,当使用非递归的方法时,先给定网络蜘蛛一个要访问的网页集合,它会把这一集合加到它将要访问站点的队列中去。网络蜘蛛发现每个新的网页时不使用调用自身的方法,而是将新发现的链接加入到该队列中。当网络蜘蛛处理完当前的网页后,它会在队列中查找要处理的下一页。

3.2 网络蜘蛛的关键技术

(1)多线程技术:由于抓取的站点URL相当多,采用单线程蜘蛛抓取时速度不够,也不能满足实际的需要。因而需要多线程技术来创建多个蜘蛛线程来同时抓取,以提高速度。

(2)网页内容抓取:网页内容抓取是基于HTTP协议之上的,网页上的资源有多种,有网页,有Word文档也有其他类型的文件,这样抓取时需要判断URL所指向资源的类型。

(3)超链分析技术:超链分析是一个比较重要的环节,需要对HTML的各种标志(tag)有一个很全面的了解。需要反复测试,考虑各种情形的发生。超链分析时从网页里提取出来的是相对于当前页的相对URL,因而需要根据当前页的绝对URL将提取的这个URL转换成绝对URL。在此过程中需要根据ParentURL(就是当前页的URL)作出各种判断。

3.3 数据库设计

在本文中主要是通过URL信息表来存储抓到的网页,从而使搜索引擎通过关键字在数据库中查找内容

4 总结与展望

目前.对于全球大多数互联网用户来说,搜索引擎是其准确获得所需要信息或者知识的最有效的工具。网络蜘蛛的研究作为一门多学科相互交叉的新兴研究方向,近年来受到国内外许多学者的关注。虽然本文对网络蜘蛛的基本功能进行了简单设计,但还存在许多的不足,只能用作最基本的网络蜘蛛实现和理论研究,与实现还有很长距离。

开发高性能的网络蜘蛛对于提高Web搜索引擎的整体性能起着至关重要的作用,也是研究和开发新一代的智能搜索引擎必然要求,本文主要研究了开发网络蜘蛛所涉及的不可或缺的关键技术、程序设计思想等。这些虽然取得了一定的成果,但由于本人学识尚浅,也还存在着一定的问题。本文只是介绍了较简单的网络蜘蛛的实现,对于如何提高网络蜘蛛的性能,以及如何促进中文智能搜索均没有太深入的研究,对于搜索引擎或者说网络蜘蛛来说,实现高性能和智能还有很长的一段路走,也是我们以后研究的重点之一。

参考文献:

[1] 王学松编著 Lucene+nutch搜索引擎开发 北京:人民邮电出版社,2008.9

[2] 刘刚、于力超,搜索引擎中网络蜘蛛的设计与实现,电脑与信息技术,2007(8).

[3] 郎波编著 Java语言程序设计 北京: 清华大学出版社 2005.8

[4] 印鉴,陈忆群,张钢.搜索引擎技术研究与发展[J].计算机工程,2005

[5] 李伟超,王兰敬。论搜索引擎工作机制和发展趋势[j]。现代情报,2002(12)

作者:柳 婷

第4篇:图书管理系统设计报告

一系统开发的目标与意义

1.1设计题目

此次VFP课程设计是综合应用所学过的数据库理论知识,自行设计并实现一个较为完整的应用系统。结合一个实际信息系统开发,初步掌握数据库管理信息系统的方案设计、论证和分析方法。正确运用所学课程的基本理论和知识,了解在Windows环境下,使用Visual FoxPro 6.0开发管理信息系统所需的计算机软、硬件环境。进一步深刻理解Visual FoxPro 6.0,合理设计并建立数据库,建立数据库中表与表之间的关系。在理论教学的基础上,进一步理解可视化编程的基本概念,熟练掌握可视化编程的方法和步骤。通过编程和上机调试,提高计算机应用与开发水平,特别是VFP平台的开发水平和能力,提高解决实际问题的能力。从软件工程的角度,初步树立正确的程序设计思想,从系统分析、系统设计、系统实现、系统评价出发。培养分析问题、解决问题的能力。提高收集、查阅资料和撰写项目文档的能力。

1.2开发意义

针对图书馆特点,图书管理系统实现后,能够使界面友好美观操作简单易行。全面自动化信息管理,可随时掌握图书的进存、借阅等信息,查询灵活方便,数据存储安全可靠。进而提高工作效率。改善后的图书管理系统将功能全面,实用性强。

1.3系统开发过程

1.3.1 分析阶段

本阶段主要工作是信息的收集,正所谓好的开度等于成功的一半。通过信息的收集工作来确定系统的目标、软件的总体思路以及所需要的时间。

1.3.2设计阶段

在本阶段认真设计可以体会到什么叫事半功倍。详细的规划具体需要完成的任务、输入输出的程序以及采用的数据结构,最好通过一定的算法描述工具详细描述算法。

1.3.3实施阶段

本阶段要运用(1)系统论思想,把所做的大系统分解成几个小系统,但要保证小系统即个功能模块受高一级系统控制。(2)“自上而下”的设计思想。每一给小程序都可独立、精确运行,但严格受制与高一级程序。

1.3.4维护阶段

本阶段测试系统的性能是关键,通过测试找出设计错误、程序错误、算法错误。通过此阶段积累自己的设计经验。

1.4开发平台本系统是在WINDOWS XP的操作系统使用VisualFoxPro 6.0开发制作的,硬件环境是P4,256M内存以及1024*768分辨率。

二系统分析

2.1 用户需求

通过本图书查询系统,用户可以轻而易举的查到图书信息、借阅人信息以及节约人与图书之间的各种关系。例如:(1)输入借阅人编号可以查阅到其解了哪些书,同时查到这些书籍的信息(作者、出版社、出版年、借还日期等);输入书籍名称或书籍编号可以查阅到书籍信息及借阅人信息(姓名、所属单位、联系方式等)。(2)数据的输出,可以把查阅到的各方面信息通过报表形式输出。

2.2可行性分析 通过对所收集的数据和在设计阶段所需要的各项功能进行分析,最终得出所学设计的软件系统是否可行。并对所存在的问题加以解决;所存在的错误加以纠正。

2.2.1数据分析 在分析阶段完成,收集各方面信息,使所作的软件功能完备,方便可行。 学生基本情况信息:主要包括姓名、性别、学号、所属单位、出生年月等

进书基本情况信息:主要包扩书名、图书分类编号、作者、出版社、出版日期、购入日期等 借书基本情况查询:主要包括借阅者姓名、借书日期、应还书日期等。在分析阶段作出以下图表,为实施阶段打下良好基础。

图1 “图书管理系统”数据结构图

2.2.2功能分析本系统具有信息录入、修改、查询、信息输出以及系统安全设置等功能。具体情况如下:

(1)信息录入功能:图书进书信息、学生信息、借阅信息等。

(2)修改功能:对图书信息、学生信息等进行添加修改。确保数据及时更新。

(3)信息输出功能:对所需要的信息通过打印机等输出工具进行输出。

(4)查询功能:主要把学生信息与图书信息建立关联,实现学生信息与图书信息的互动。能够方便快捷的实现图书被借阅,和学生借阅等信息的查询。

为了为实施阶段打下基础,做功能结构图如下:

图 书 管 理 系 统

系统介绍数据查询数据录入维护信息输出退出

系统介绍界面系统登陆界面学生信息查询书籍信息查询借阅信息查询学生信息录入新书信息录入借阅信息录入学生信息输出书籍信息输出图书去向输出推出系统界面

图2系统功能结构图

三 系统结构设计

3.1数据库的建立

3.1.1 表的建立本系统共建立三个表,分别是借书表、进书表、学生基本情况表。给表中所包含的信息见2.2.1数据分析所示。

3.1.2 表的关联

所以是表与表这间建立联系的纽带。在本系统所涉及的三个表中索书号和借阅证号都可以作为唯一标示纪录的索引关键字。但考虑到数据修改时是否方便,所以使用学生基本情况表作为父表,以借阅证号作为主索引,避免了关键字出复值。在借书表中涉及到“书被谁借去了”所以可以用借阅证号位关键字把学生基本情况表和借书表建立起一一对应的关系。在学生基本情况表中涉及到“某学生截了那本书”故可以以索书号作为关键字建立唯一索引。因为索书号是唯一确定的,虽让建立的是唯一索引,却也可以收到主索引的效果。总而言之,在借书表与学生基本情况表之间以借阅证号位关键字建立对应关系,再进书表与学生基本情况表之间用索书号建立起一一对应的关系,最终实现三个表之间的互动。

3.1.3表结构的建立与数据的录入

打开了Visual FoxPro软件,运行文件菜单中的新建按钮,选择表和新建文件,同时设置好表名及路径并保存,然后在出现表设计器中进行设计。以下为三个表的设置结构及录入的记录:

部分记录如下:

图3借书表结构及部分数据截图

部分数据如下:

图4进书表结构及部分数据截图

部分数据如下

图5 学生节本情况结构及部分数据截图

3.2系统的设计与实现

3.2.1系统界面与表单设计

漂亮简捷的系统界面将给使用者一个好的印象,是一套系统的门面。设计的成功与否,见关系到系统的前景与市场。本套系统的界面设计及实现程序如下:

图6 系统登陆截图

设计步骤如下:

新建表单“系统登陆.scx”,创建command

1、

2、3,label

1、

2、3,combo1和text1。

设置text1的caption属性为“图书管理系统”,text2的caption属性为“操作员”, text3的caption属性为“密码”, 并设置字体、颜色、大小等内容使其美观。Label1的caption属性为“确定”,同理label

2、3为“取消、退出”

定义command1控件的click事件,代码如下:

3.2.2数据查询表单设计

数据查询包括按学生学号查询学生的具体信息、按书籍的名称查询书籍的具体信息和借阅情况等。下面列举单表查询表单如进书表.scx和多表查询表单如图书去向情况和图书借阅情况.scx说明数据查询的设计方法,进书表.scx的运行效果如下图所示:

图7 图书信息查询系统截图

设计步骤如下:

此表单的设计主要是练习表单向导的用法。新建表单→表单→向导→字段选取→选择表单样式→排序次序→完成→运行。

用表单向导来设计表单为使用者带来极大的便利,尤其是对于我们初学者。但影响创造力的发挥和一些功能的实现。

索书号查询表单的运行效果如下:

图8 索书号查询截图

设计步骤如下:

★此表单涉及主要是练习用程序和命令来实现查询的目的。查询的关键是command1即查询按钮的属性设置。其实现代码如下:

command2即退出按钮的代码为release thisform;

推出系统地实现:

退出系统地实现主要是通过command

1、2的单击事件click来实现的。其运行效果图如下:

图9 退出系统截图

设计步骤如下

★command1即YES按钮的实现代码为 ,command2即NO按钮的实现代码为release thisform。

3.2.3 报表的设计

在数据库应用系统中,常需要将数据处理结果以报表形式打印出来。在本套系统的报表设计、显示、答应报表的功能主要用报表设计起来实现。例如下图:

运行后的结果如图所示:

图10报表设计器及部分数据截图

在报表设计过程中,主要用到表设计器和表向导。为能用到报表设计器的高级操作,我会在以后努力学习表设计器的高级操作,弥补这次课程设计的一个缺憾。

3.2.4主菜单的设计

主菜单是用户使用本系统的主要途径,所以合理的设计至关重要,本系统的主菜单是通过菜单设计器来完成,使用的是菜单设计器的非快捷菜单方式,在主菜单确定后,分别再编辑各个子菜单项、命令、过程。本系统使用了命令及过程调用表单的方式。设计步骤如下:

创建第一级菜单。在“项目管理器”中选择“其他”选项卡,再选择“菜单”选项,然后单击“新建”按钮。出现菜单设计器,输入各菜单名称及结果,建立本系统所需要的菜单,如下图所示:

图11 系统主菜单截图

★在创建主菜单后,即开始设计子菜单。单击子菜单项后的“创建”按钮,可创建其子菜单。如下图所示:

图12 系统子菜单编辑截图

3.2.5主程序设计

主程序是系统运行时执行的主文件,设计主程序的方法为:在“项目管理器”中选择“代码”选项卡,再选择“程序”选项,然后选中一个程序文件,本系统中为“MAIN”,单击右键弹出快捷菜单,选择“设置主文件”,就可设置一个程序为主文件。

本系统的主程序代码如下:

四 系统操作说明

★双击 快捷方式,进入到登陆系统。

★输入操作员账号和密码,单击确定进入到系统介绍界面。单击 系统操作界面。见看到菜单栏 。在“系统介绍”中有“用户更改”和“系统主页”子菜单。在“数据查询”中涉及到借阅信息、图书去向、姓名查询、索书号查询等子菜单。报表打印中涉及到借书表、进书表、学生信息、和借阅情况等表格。在退出系统一栏中,涉及到系统推出的确认,确定要退出单击YES,否则单击NO。

五 结束语

经过为期两周的课程设计可谓受益匪浅。经过时间才真正的地把文字化为了知识,才真正的为我所用。认识到自己在学习过程中的缺点和不足。为以后的学习生活积累了宝贵的经验和教训。心得体会如下:

★再做vfp系统开发时一定要做好信息的收集工作,否则后即工作将坠入五里雾中。信息收集时要求尽可能的考虑周全。这才能为设计阶段打下一个良好的基础。

★在系统的设计过程中,最好能集思广益,多听取一点别人的意见和创意。使程序尽可能完美。一定要学会用算法描述工具,把自己的的意图详细简明的记录下来。

★在为文件命名是尽可能不要因其混淆,尽量由数字或字母。在系统设计中我把“系统登陆、系统登录、登陆系统”三者混淆了。为自己带来了不尽的苦难。并且均用汉字作为文件名,。这样虽然不易引起混淆,但是影响工作的效率。

★要学会设置文件路径,尤其是用向导时。要学会用项目管理器,既可以提高工作效率,又减少了出错的几率。

★★最后诚恳的向老师您提一点建议,如果您一个学期教我们做一套系统,在做这套系统的同时穿插着讲知识点,我幼稚的以为效果会更好,避免了在做课程设计已开始的时候找不到北!

六 参考文献:

㈠李春葆编著.Visual Fox Pro7.0数据库系统设计与开发. 北京:清华大学出版社,2003.8 ㈡李春葆编著.Visual Fox Pro6.0高级编程(应用系统设计篇). 北京:清华大学出版社,2000

㈢史济民,汤观全编著.Visual Fox Pro及其应用系统开发. 北京:清华大学出版社,2000 ㈣蔡卓毅,林盛雄,林羽扬,黄竺编著.Visual Fox Pro6.0数据库程序设计与实例. 北京:冶金工业出版社,2003

㈤史德芬编著.全国计算机等级考试二级真题解析——Visual Fox Pro程序设计.北京:海洋出版社,2003

第5篇:图书管理系统课程设计绪论

绪论

1.1 课题背景意义

在学校现代化的管理中,图书馆管理系统也是其中非常重要的一部分,然而,用大型软件系统来于小型的图书管理,不啻于“杀鸡用牛刀”,因此小型的的软件对于这种管理自然有十分重要作用。某图书馆需要管理其各种人员信息和图书信息,希望实现办公的信息化,通过建立一个图书管理系统来管理图书馆。

1.2国内外研究的现状

国内在信息化这一方面做的没有国外好,因此现在需要大量这样的程序人员,

图书馆管理系统这一块也需要做大量改进。

3共30页

第6篇:图书仓库管理系统的设计

摘 要

本系统主要完成对图书仓库的库存管理,包括图书入库、出库、库存,员工信息,供应商信息以及密码管理等六个方面。系统可以完成对各类信息的浏览、查询、添加、删除、修改、报表等功能。

系统的核心是入库、库存和出库三者之间的联系,每一个表的修改都将联动的影响其它的表,当完成入库或出库操作时系统会自动地完成库存的修改。查询功能也是系统的核心之一,在系统中即有单条件查询和多条件查询,也有精确查询和模糊查询,系统不仅有静态的条件查询,也有动态生成的条件查询,其目的都是为了方便用户使用。系统有完整的用户添加、删除和密码修改功能,并具备报表打印功能。

系统采用Microsoft Office中的Access 2000来设计数据库,并使用当前优秀的开发工具—Delphi 6.0 ,它有着最为灵活的数据库结构,对数据库应用有着良好的支持。

论文主要介绍了本课题的开发背景,所要完成的功能和开发的过程。重点的说明了系统设计的重点、设计思想、难点技术和解决方案。

关键字:数据库,SQL语言,Delph 6,数据库组件,仓库管理 目 录

第一章 引言 „„„„„„„„„„„„„„„„„„„„„„„„„„„„„1 1.1 课题来源 „„„„„„„„„„„„„„„„„„„„„„„„„„1 1.2 开发工具的选择 „„„„„„„„„„„„„„„„„„„„„„„2 1.3 所做的主要工作 „„„„„„„„„„„„„„„„„„„„„„„3 第二章 数据库概论 „„„„„„„„„„„„„„„„„„„„„„„„„„4 2.1 数据库的发展 „„„„„„„„„„„„„„„„„„„„„„„„4 2.1.1 数据库的发展 „„„„„„„„„„„„„„„„„„„„„„4 2.1.2 数据库阶段的特点 „„„„„„„„„„„„„„„„„„„„5 2.1.3 数据库技术 „„„„„„„„„„„„„„„„„„„„„„„6 2.2 数据库理论基础 „„„„„„„„„„„„„„„„„„„„„„„7 2.2.1 数据库模型 „„„„„„„„„„„„„„„„„„„„„„„7 2.2.2 数据库体系结构 „„„„„„„„„„„„„„„„„„„„10 2.2.3 数据的独立性 „„„„„„„„„„„„„„„„„„„„„11 2.2.4 范式 „„„„„„„„„„„„„„„„„„„„„„„„„11 2.3 SQL语言基础 „„„„„„„„„„„„„„„„„„„„„„„13 2.3.1 SQL简介 „„„„„„„„„„„„„„„„„„„„„„„13 2.3.2 SQL查询 „„„„„„„„„„„„„„„„„„„„„„„13 2.3.3 SQL数据更新 „„„„„„„„„„„„„„„„„„„„„14 第三章数据库开发工具 „„„„„„„„„„„„„„„„„„„„„„„16 3.1 Delphi 6.0 简介 „„„„„„„„„„„„„„„„„„„„„„„16 3.2 Delphi 6.0 控件 „„„„„„„„„„„„„„„„„„„„„„„17 3.2.1 ADO数据访问组件 „„„„„„„„„„„„„„„„„„„17 3.2.2 数据控制类DataControl „„„„„„„„„„„„„„„„„18 3.2.3 数据访问类DataAccess „„„„„„„„„„„„„„„„„18 3.2.4 SQL语言在Delphi中的应用 „„„„„„„„„„„„„„„19 3.3 Access 简介 „„„„„„„„„„„„„„„„„„„„„„„„21 第四章 系统总体设计 „„„„„„„„„„„„„„„„„„„„„„„„23 4.1 系统需求分析 „„„„„„„„„„„„„„„„„„„„„„„23 4.2 系统概要设计 „„„„„„„„„„„„„„„„„„„„„„„25 4.2.1 系统结构设计 „„„„„„„„„„„„„„„„„„„„„25 4.2.2 数据库设计 „„„„„„„„„„„„„„„„„„„„„„27 4.2.2.1 ER图设计 „„„„„„„„„„„„„„„„„„„„27 4.2.2.2 数据库表格设计„„„„„„„„„„„„„„„„„„29 4.3系统详细设计„„„„„„„„„„„„„„„„„„„„„„„„34 第五章 系统应用程序设计 „„„„„„„„„„„„„„„„„„„„„„37 5.1 系统窗体模块组成„„„„„„„„„„„„„„„„„„„„„„37 5.2 数据模块窗体设置„„„„„„„„„„„„„„„„„„„„„„38 5.3 主窗体功能模块的实现„„„„„„„„„„„„„„„„„„„„39 5.4 入库、出库窗体模块的实现„„„„„„„„„„„„„„„„„„43 5.5 查询功能的实现„„„„„„„„„„„„„„„„„„„„„„„51 5.6 系统登陆窗体模块的实现„„„„„„„„„„„„„„„„„„„52 5.7 用户管理功能的实现„„„„„„„„„„„„„„„„„„„„„54 5.7.1 用户管理主窗体 „„„„„„„„„„„„„„„„„„„„54 5.7.2 密码修改窗体模块的实现 „„„„„„„„„„„„„„„„54 5.7.3 用户注册窗体模块的实现 „„„„„„„„„„„„„„„„55 5.7.4 用户注销窗体模块的实现 „„„„„„„„„„„„„„„„57 结束语 „„„„„„„„„„„„„„„„„„„„„„„„„„„„„„„59 致谢 „„„„„„„„„„„„„„„„„„„„„„„„„„„„„„„„60 参考文献 „„„„„„„„„„„„„„„„„„„„„„„„„„„„„„61 第一章 引 言 §1.1 课题来源

随着社会经济的迅速发展和科学技术的全面进步,计算机事业的飞速发展,以计算机与通信技术为基础的信息系统正处于蓬勃发展的时期。随着经济文化水平的显著提高,人们对生活质量及工作环境的要求也越来越高。书籍做为人类的精神食粮,在现代社会中越来越受到重视,大量的书籍出现在市场上,人们有了各种各样不同的选择。与此同时,为了管理大量的图书,图书仓库也大量的出现,仓库的管理问题也就提上了日程。随着图书的大量增加,其管理难度也越来越大,如何优化仓库的日常管理也就成为了一个大众化的课题。

在计算机飞速发展的今天,将计算机这一信息处理利器应用于仓库的日常管理已是势必所然,而且这也将为仓库管理带来前所未有的改变,它可以带来意想不到的效益,同时也会为企业的飞速发展提供无限潜力。采用计算机管理信息系统已成为仓库管理科学化和现代化的重要标志,它给企业管理来了明显的经济效益和社会效益。主要体现在:

极大提高了仓库工作人员的工作效率,大大减少了以往入出存流程繁琐,杂乱,周期长的弊端。 基于仓库管理的全面自动化,可以减少入库管理、出库管理及库存管理中的漏洞,可以节约不少管理开支,增加企业收入。

仓库的管理的操作自动化和信息的电子化,全面提高了仓库的管理水平。

随着我国改革开放的不断深入,经济飞速的发展,企业要想生存、发展,要想在激烈的市场竞争中立于不败之地,没有现代化的管理是万万不行的,仓库管理的全面自动化、信息化则是其中极其重要的部分。为了加快仓库管理自动化的步伐,提高仓库的管理业务处理效率,建立仓库管理系统已变得十分心要。

入库、库存、出库还是现在企业图书仓库管理的常规基本模式,虽然,最近又出现了很多新的管理模式,如:基于零库存思想的沃尔玛特管理方式,但这些新的思想在中国大部分企业的管理中还是难以实现的。所以如何设计好仓库管理系统,尽可能地减少仓库管理的重复性和低效性就成为当前最为重要的问题。图书仓库管理的核心是入库、库存和出库之间的联系,如何处理好三者之间的关系是系统最为关键的部分。另外,员工信息和供应商信息管理也是仓库管理中一个必不可少的部分,它提供着与入库和出库相关的地一些信息,使得整个系统更加完整,更加实用。 通过对仓库管理日常工作的详细调查,搜集了大量的资料,从系统结构的组织,功能的实现,技术的要求以及可行性等多方面进行考虑,认为本课题是一个适应现今图书仓库管理需求的计算机信息管理系统,具有一定的实际开发价值和使用价值。 §1.2 开发工具的选择

自Java诞生以来,随着Internet技术的普及和应用需求的变化,以第四代语言为主的应用开发产品发生了较大的变化,它们不仅已成为人们开发应用的开发工具,而且很多产品已发展成为一种强有力的应用开发环境。这些新型的开发工具通常以一种集成软件包的形式提供给开发人员,被称为Studio(工作室)或Suite(程序组)。例如,微软的Visual Studio 6.0,Borland公司的Delphi 6.0等数据库辅助开发工具。

现在,市场上可以选购的应用开发产品很多,流行的也有数十种。目前在我国市场上最为流行、使用最多、最为先进的可用作企业级开发工具的产品有: Microsoft公司的Visual Basic 6.0版 Microsoft公司的Visual C++6.0版 Borland公司的Delphi 6.0版

在目前市场上这些众多的程序开发工具中,有些强调程语言的弹性与执行效率;有些则偏重于可视化程序开发工具所带来的便利性与效率的得高,各有各的优点和特色,也满足了不同用户的需求。然而,语言的弹性和工具的便利性是密不可分的,只有便利的工具,却没有弹性的语言作支持,许多特殊化的处理动作必需要耗费数倍的工夫来处理,使得原来所标榜的效率提高的优点失去了作用;相反,如果只强调程语言的弹性,却没有便利的工具作配合,会使一些即使非常简单的界面处理动作,也会严重地浪费程序设计师的宝贵时间。

而Delphi是一个非常理想选择。Delphi 6 是操作系统中快速应用开发环境的最新版本。它也是当前Windows平台上第一个全面支持最新Web服务的快速开发工具。无论是企业级用户,还是个人开发者,都能够利用Delphi 6 轻松、快捷地构建新一代电子商务应用。Delphi 6 是惟一支持所有新出现的工业标准的RAD环境,包括XML(扩展标记语言)/XSL(可扩展样式语言),SOAP(简单对象存取协议)和WSDL(Web服务器描述语言)等。 Delphi 6 是可视化的快速应用程序开发语言,它提供了可视化的集成开发环境,这一环境为应用程序设计人员提供了一系列灵活而先进的工具,可以广泛地用于种类应用程序设计。在Delphi 6 的集成开发环境中,用户可以设计程序代码、运行程序、进行程序错误的调试等,可视化的开发方法降低了应用程序开发的难度。Delphi的基础编程语言是具有面向对象特性的Pascal语言,即Object Pascal 。Object Pascal具有代码稳定、可读性好、编译速度快等优点,并将面向对象的概念移植到了Pascal语言中,使这种基础语言有了新的发展空间。

使用Delphi 6.0 ,我们几乎可以作任何事情,还可以撰写种各种类型的应用程序,动态链接库(DLL)、CON、或CORBA对象,CGI/ISAPI程序,Microsoft Back Office应用程序。程序的规模小到简单的个人数据库应用,大到复杂的企业的多层次分布式系统,都可以使用Delphi进行开发,其友好的集成开发界面,可视化的双向开发模式,良好的数据库应用支持高效的程序开发和程序运行,备受广大程序开发人员的好评。尤其是Delphi对数据库应用的强大支持,大大提高了数据库应用软件开发的效率,缩短了开发周期,深受广大数据库应用程序设计人员的喜爱。Delphi为数据库应用开发人员提供了丰富的数据库开发组件,使数据库应用开发功能更强大,控制更灵活,编译后的程序运行速度更快。 §1.3 本文所做工作

引言部分介绍了本系统的课题来源以及对数据库开发工具的选择。

第二章介绍了数据库的发展,关系数据库,数据库体系结构,并系统介绍了SQL语言,为设计和理解应用程序做了铺垫。

第三章系统介绍了Delphi 6.0及其部分控件,SQL语言在Delphi 6.0中的应用,以及Access等。

第四章是本文的主体,按照软件工程的要求,从需求分析开始,经过概要设计最后到详细设计,完成对整个系统的设计。

第五章根据第四章的设计结果利用Access 2000和Delphi 6.0进行了具体的窗体和应用程序设计。

总结部分介绍了设计体会和编程体会,并指出了系统设计中的不足和改进的方向 第二章 数据库概论 §2.1 数据库的发展

数据库处理在信息系统的研究中一直是非常重要的主题,然而,近年来,随着World Wide Web(WWW)的猛增及Internet技术的迅速发展,使得数据库技术之时成为最热门技术之一。数据库技术能使Internet应用超越具有早期应用特点的简单的发布。同时,Internet技术提供了一种向用户发布数据库内容的标准化的访问方法。这些技术没有脱离经典数据库技术的要求。它们只是加重了数据库技术的重要性。

数据库的设计和开发及包括艺术有包括工程。理解用户的需求,然后,把它们转变为有效的数据库设计是一个艺术过程。把设计转变为实际的数据库,并且这些数据库带有功能完备、高效能的应用,是一个工程过程。

数据库的目的是帮助人们跟踪事务。经典的数据库应用涉及诸如订单、顾客、工作、员工、学生、电话之类的项,或其它数据量较大、需要密起关注的事务。最近,由于数据库的普及,数据库技术已经被应用到了新的领域,诸如用于Internet的数据库或用于公司内联网的数据库。数据库也被越来越多地应用于生成和维护多媒体应用程序上。 计算机的数据处理应用,首先要把大量的信息以数据形式存放在存储器中。存储器的容量、存储速率直接影响到数据管理技术的发展。从1956年生产出第一台计算机到现在,存储器的发展,为数据库技术提供了良好的物质基础。

使用计算机以后,数据处理的速度和规模,无论是相对于手工方式,还是机械方式,都有无可比拟的优势。通常在数据处理中,计算是比较简单的而数据的管理却比较复杂。数据管理是指数据的收集、整理、组织、存储、维护、检索、传送等操作,这部分操作是数据处理业务的基本环节,而且是任何数据处理业务中必不可少的共有部分。数据管理技术的优劣,将直接影响数据处理的效率。

2.1.1 数据库的发展

数据管理技术的发展,与硬件(主要是外存)、软件、计算机应用的范围有密切的联系。数据管理技术的发展经过三个阶段:人工管理阶段、文件系统阶段和数据库阶段。

人工管理阶段和文件系统阶段都有着相当多的缺陷,诸如数据冗余性 ,数据不一致性以及数据联系弱等等。也正是由于这些原因,促使人们研究新的数据管理技术,从而产生了数据库技术。 20世纪60年代末发生的三件大事,层次模型IMS系统的推出、关于网状模型DBTG报告的发表以及关于关系模型论文的连续发表标志着数据管理技术进入数据库阶段。进入70年代以后,数据库技术得到迅速发展,开发了许多有效的产品并投入运行。数据库系统克服了文件系统的缺陷,提供了对数据更高级更有效的管理。

当进入数据库阶段后,随着数据管理规模一再扩大,数据量急剧增加,为了提高效率,开始时,人们只是对文件系统加以扩充,在应用文件中建立了许多辅助索引,形成倒排文件系统。但这并不能最终解决问题。在20世纪60年代末,磁盘技术取得重要进展,具有数百兆容量和快速存取的磁盘陆续进入市场,成本也不高,为数据库技术的产生提供了良好的物质条件。 2.1.2 数据库阶段的特点

(1)减少数据的重复(Redundancy can be reduced)

当在一个非数据库系统当中,每一个应用程序都有属于他们自己的文件,由于无法有系统建立的数据,因此常常会造成存储数据的重复与浪费。例如:在一家公司当中,人事管理程序与工资管理程序或许都会使用到职员与部门的信息或文件,而我们可以运用数据库的方法,把这两个文件整理起来,以减少多余的数据,过度地占用存储空间。 (2)避免数据的不一致(Inconsistency can avoid)

本项的特色,可以说是延伸前项的一个特点,要说明这样的一个现象,我们可以从下面这个实例来看:若是在同一家公司当中,职员甲在策划部门工作,且职员甲的记录同时被存放在数据库的两个地方,而数据库管理系统却没有对这样重要的情况加以控制,当其中一条数据库被修改时,便会造成数据的不一致,但是,对于一个健全的数据库管理系统而言,将会对这样的情况加以控制,但有时并不需要刻意消除这种情形,应当视该数据库的需求与效率来决定。 (3)数据共享(Data shared)

对于数据共享的意义,并不是只有针对数据库设计的应用程序,可以使用数据库中的数据,对于其他撰写好的应用程序,同样可以对相同数据库当中的数据进行处理,进而达到数据共享的目的。 (4)强化数据的标准化(Standard can be enforced)

由数据库管理系统,对数据做出统筹性的管理,对于数据的格式与一些存储上的标准进行控制,如此一来,对于不同的环境的数据交换(Data Interchange)上将有很大的帮助,也能提高数据处理的效率。

(5)实践安全性的管理(Security restriction can be applied)

通过对数据库完整的权限控制,数据库管理者可以确认所有可供用户存取数据的合法途径渠道,并且可以事先对一些较重要或关键性的数据进行安全检查,以确保数据存取时,能够将任何不当损毁的情形降至最低。

(6)完整性的维护(Integrity can be maintained)

所谓完整性的问题,就是要确认某条数据在数据库当中,是正确无误的。正如(2)所述,若是无法控制数据的不一致性,便会产生完整性不足的问题,所以,我们会发现,当数据重复性高的时候,数据不完整的情形也会增加,当然,若是数据库的功能完整,将会大大地提高数据完整性,也会增加数据库的维护能力与维护简便性。

(7)需求冲突会获得平衡(Conflicting requirements can be balance)

在一个较大型的企业当中,用户不同的需求,往往会造成系统或数据库在设计上的困扰,但是一个合适的数据库系统,可以通过数据库管理员的管理,将会有效地整理各方面的信息,对于一些较重要的应用程序,可以适时地提供较快速的数据存取方法与格式,以平衡多个用户在需求上的冲突。

上述七个方面构成了数据库系统的主要特征。这个阶段的程序和数据间的联系可用下图表示: 2.1.3 数据库技术

从文件系统发展到数据库系统是信息处理领域的一个重大变化。在文件系统阶段,人们关注的中心问题是系统功能的设计,因而程序设计处于主导地位,数据只起着服从程序需要的作用。在数据库方式下,信息处理观念已为新体系所取代,数据占据了中心位置。数据结构的设计成为信息系统首先关心的问题,而利用这些数据的应用程序设计则退居到以既定的数据结构为基础的外围地位。

目前世界上已有数百万个数据库系统在运行,其应用已经深入到人类社会生活的各个领域,从企业管理、银行业务、资源分配、经济预测一直到信息检索、档案管理、普查统计等。并在通信网络基础上,建立了许多国际性的联机检索系统。我国20世纪90年代初在全国范围内装备了12个以数据库技术为基础的大型计算机系统,这些系分布在邮电、计委、银行、电力、铁路、气象、民航、情报、公安、军事、航天和财税等行业。

数据库技术还在不断的发展,并且不断地与其它计算机技术相互渗透。数据库技术与网络通信技术相结合,产生了分布式数据库系统。数据库技术与面向对象技术相结合,产生了面向对象数据库系统。

在数据库技术中有四个名词,其概念应该分清。

(1)数据库(database,DB):DB是统一管理的相关数据的集合。DB能为各种用户共享,具有最小冗余度,数据间联系密切,而又有较高的数据独立性。

(2)数据库管理系统(Database Management System,DBMS):DBMS是位于用户与操作系统之间的一层数据管理软件,为用户或应用程序提供访问DB的方法,包括DB的建立、查询、更新及各种数据控制。DBMS总是基于某种数据模型,可以分为层次型、网状型、关系型和面向对象型DBMS。

(3)数据库系统(Database System,DBS):DBS是实现有组织地、动态地存储大量关联数据,方便多用户访问的计算机软件、硬件和数据资源组成的系统,即采用了数据库技术的计算机系统。 (4)数据库技术:这是一门研究数据库的结构、存储、管理和使用的软件学科。数据库技术是操作系统的文件系统基础上发展起来的。而DBMS本身要在操作系统的支持下才能工作。数据库不仅用到数据结构的知识,而且丰富了数据结构的内容。在关系数据库中要用到集合论、数理逻辑的理论。因此,数据库技术是一门综合性较强的学科。 §2.2数据库理论基础 2.2.1 数据库模型

从20世纪50年代中期开始,计算机的应用由科学研究部门逐步扩展到企业、行政部门。至60年代,数据处理成为计算机的主要应用。数据库技术作为数据管理技术,是计算机软件领域的一个重要分支,产生于60年代末。现已形成相当规模的理论体系和实用技术。

模型是对现实世界的抽象。在数据库技术中,我们用模型的概念描述数据库的结构与语义,对现实世界进行抽象,表示实体类型及实体间联系的模型称为“数据模型” 。 目前广泛作用的数据模型可分为两种类型。

一种是独立于计算机系统的模型,完全不涉及信息在系统中的表示,只是用来描述某个特定组织所关心的信息结构,这类模型称为“概念数据模型” 。要领模型用于建立信息世界的数据模型,强调其语义表达功能,应该概念简单、清晰,易于用户理解,它是现实世界的第一层抽象,是用户和数据库设计人员之间进行交流的工具。这一其中著名的模型是“实体联系模型” 。 另一种数据模型是直接面向数据库的逻辑结构,它是现实世界的第二层抽象。 这类模型涉及到计算机系统和数据库管理系统,又称为“结构数据模型” 。例如,层次、网状、关系、面向对象等模型。这类模型有严格的形式化定义,以便于在计算机系统中实现。

(1)层次模型。用树型结构表示实体类型及实体间联系的数据模型。树的结点是记录类型,每个非根结点有且只有一个父结点。上一层记录类型和下一层记录类型间联系是1∶N联系。 层次模型的特点是记录之间的联系通过指针实现,查询效率较高。但层次模型有两个缺点:一是只能表示1∶N联系,虽然有多种辅助手段实现了M∶N联系,但都较复杂,用户不易掌握,二是由于树型结构层次顺序的严格和复杂,引起数据的查询和更新操作也很复杂,因此,编写应用程序也很复杂。

(2)网状模型。用有向图结构表示实体类型及实体间联系的数据模型。。1969年DBTG报告提出的数据模型是网状模型的主要代表。有向图中的结点是记录类型,有向边表示从箭尾一端的记录类型到箭头一端的记录类型间联系是1∶N联系。

网状模型的特点:记录之间联系通过指针实现,M∶N联系也容易实现(每个M∶N联系可拆成两个1∶N联系),查询效率较高。网状模型的缺点是编写应用程序比较复杂,程序员必须熟悉数据库的逻辑结构。由于层次系统和网状系统的应用程序编制比较复杂,因此,从20世纪80年代中期起,其市场已被关系系统所取代。但是使用这两种模型建立起的许多数据库仍然在正常运转,只是在外层加了个关系数据库语言的接口。网状模型有许多成功的产品,20世纪70年代的产品大部分网状系统,例如,Honeywell公司的IDS/Ⅱ、HP公司的IMAGE/3000、Burroughs公司的DMSⅡ、Umivac公司的DMS1100、Cullinet公司的IDMS、Cimcom公司的TOTAL等

(3)关系模型。关系模型的主要是用二维表格结构表达实体集,用外键表示实体间联系。关系模型是由若干个关系模式组成的集合。关系模式相当于前面提到的记录类型,它的实例称为关系,每个关系实际上是一张二维表格。

关系模型和层次、网状模型的最大判别是用关键码而不是用指针导航数据,表格简单用户易懂,编程时并不涉及存储结构,访问技术等细节。关系模型是数学化模型。SQL语言是关系数据库的标准化语言,已得到了广泛的应用。20世纪70年代对关系数据库的研究主要集中在理论和实验系统的开发方面。80年代初才形成产品,但很快得到广泛的应用和普及,并最终取代了层次、网状数据库产品。现在市场上典型的关系DBMS产品有DB

2、ORACLE、SYBASE、INFORMIX和微机型产品Foxpro、Access等。

关系模型和网状、层次模型的最大区别是:关系模型用表格数据而不是通过指针链来表示和实现实体间联系。关系模型的数据结构简单、易懂。只需用简单的查询语句就可对数据库进行操作。 关系模型是数学化的模型,可把表格看成一个集合,因此集合论、数理逻辑等知识可引入到关系模型中来。关系模型已是一个成熟的有前途的模型,已得到广泛应用。

(4)面向对象模型。目前,关系数据库的使用已相当普遍,但是,现实世界中仍然存在着许多含有复杂数据结构的应用领域,例如,CAD数据、图形数据等,而关系模型在这方面的处理能力就显得力不从心。因此,人们需要更高级的数据库技术来表达这类信息。面向对象的概念最早出现在程序设计语言中,随后迅速渗透到计算机领域的每一个分支。面向对象数据库是面向对象概念与数据库技术相结合的产物。

面向对象模型能完整地描述现实世界的数据结构,具有丰富的表达能力,但模型相对较复杂,涉及的知识面也广,因此面向对象数据库尚未达到关系数据库那样的普及程度。

2.2.2 数据库体系结构

数据库的体系结构分三级:内部级(internal),概念级(conceptual)和外部级(external)。这个三级结构有时也称为“三级模式结构”,或“数据抽象的三个级别”,最早是在1971年通过的DBTG报告中提出,后来收入在1975年的美国ANSI/SPARC报告中。虽然现在DBMS的产品多种多样,在不同的操作系统支持下工作,但是大多数系统在总的体系结构上都具有三级模式的结构特征。从某个角度看到的数据特性称为“数据视图”(data view)。

外部级最接近用户,是单个用户所能看到的数据特性。单个用户使用的数据视图的描述称为“外模式”。

概念级涉及到所有用户的数据定义,是全局的数据视图。全局数据视图的描述称为“概念模式”。 内部级最接近于物理存储设备,涉及到实际数据存储的结构。物理存储数据视图的描述称为“内模式”。

数据库的三级模式结构是数据的三个抽象级别。它把数据的具体组织留给DBMS去做,用户只要抽象地处理数据,而不必关心数据在计算机中的表示和存储,这样就减轻了用户使用系统的负担。 三级结构之间往往差别很大,为了实现这三个抽象级别的联系和转换,DBMS在三级结构之间提供两个层次的映象(mappings):外模式/模式映象,模式/内模式映象。此处模式是概念模式的简称。

2.2.3 数据的独立性

由于数据库系统采用三级模式结构,因此系统具有数据独立性的特点。在数据库技术中,数据独立性是指应用程序和数据之间相互独立,不受影响。数据独立性分成物理数据独立性和逻辑数据独立性两级。 (1)物理数据独立性

如果数据库的内模式要进行修改,即数据库的存储设备和存储方法有所变化,那么模式/内模式映象也要进行相当的修改,使概念模式尽可能保持不变。也就是对内模式的修改尽量不影响概念模式,当然,对于外模式和应用程序的影响更小,这样,我们称数据库达到了物理数据独立性。 (2)逻辑数据独立性

如果数据库的概念模式要进行修改,譬如增加记录类型或增加数据项,那么外模式/模式映象也要进行相应的修改,使外模式尽可能保持不变。也就是对概念模式的修改尽量不影响外模式和应用程序,这样,我们称数据库达到了逻辑数据独立性。

现有关系系统产品均提供了较高的物理独立性,而对逻辑独立性的支持尚有欠缺,例如,对外模式的数据更新受到限制等。 2.2.4 范式

建立起一个良好的数据指标体系,是建立数据结构和数据库的最重要的一环。一个良好的数据指标体系是建立DB的必要条件,但不是充分条件。我们完全可以认为所建指标体系中的一个指标类就是关系数据库中的一个基本表,而这个指标类下面的一个个具体指标就是这个基本表中的一个字段。但如果直接按照这种方式建库显然还不能算最佳。对于指标体系中数据的结构在建库前还必须进行规范化的重新组织。

在数据的规范化表达中,一般将一组相互关联的数据称为一个关系(relation),而在这个关系下的每个数据指标项则被称为数据元素(data element),这种关系落实到具体数据库上就是基本表,而数据元素就是基本表中的一个字段(field)。规范化表达还规定在每一个基本表中必须定义一个数据元素为关键字(key),它可以唯一地标识出该表中其它相关的数据元素。在规范化理论中表是二维的,它有如下四个性质:

在表中的任意一列上,数据项应属于同一个属性(如图中每一列都存放着不同合同记录的同一属性数据)。

表中所有行都是不相同的,不允许有重复组项出现(如图中每一行都是一个不同的合同记录)。 在表中,行的顺序无关紧要(如图中每行存的都是合同记录,至于先放哪一个合同都没关系)。 在表中,列的顺序无关紧要,但不能重复(如图中合同号和合同名谁先谁后都没关系,但二者不可重复或同名)。

在对表的形式进行了规范化定义后,数据结构还有五种规范化定义,定名为规范化模式,称为范式。在这五种范式中,一般只用前三种,对于常用系统就足够了。而且这五种范式是“向上兼容”的,即满足第五范式的数据结构自动满足

一、

二、

三、四范式,满足第四范式的数据结构自动满足第

一、

二、三范式,„„,依此类推。

第一范式(first normal form,简称1st NF)就是指在同一表中没有重复项出现,如果有则应将重复项去掉。这个去掉重复项的过程就称之为规范化处理。在本文所讨论的开发方法里,1st NF实际上是没有什么意义的。因为我们按规范化建立的指标体系和表的过程都自动保证了所有表都满足1st NF。

第二范式(second normal form,简称 2nd NF)是指每个表必须有一个(而且仅一个)数据元素为主关键字(primary key),其它数据元素与主关键字一一对应。例如,在图l9.7中如果我们将合同号定义为主关键字(其它数据元素中的记录数据都有可能重名,故不能作为主关键字),故只要知道了一个合同记录的合同号,就可以唯一地在同一行中找到该合同的任何一项具体信息。通常我们称这种关系为函数依赖(functional depEndence)关系。即表中其它数据元素都依赖于主关键字,或称该数据元素唯一地被主关键字所标识。

第三范式(third normal form,简称 3rd NF)就是指表中的所有数据元素不但要能够唯一地被主关键字所标识,而且它们之间还必须相互独立,不存在其它的函数关系。也就是说对于一个满足了 2nd NF的数据结构来说,表中有可能存在某些数据元素依赖于其它非关键宇数据元素的现象,必须加以消除。

为防止数据库出现更新异常、插入异常、删除异常、数据冗余太大等现象,关系型数据库要尽量按关系规范化要求进行数据库设计。

§2.3 SQL语言基础 2.3.1 SQL简介

用户对数据库的使用,是通过数据库管理系统提供的语言来实现的。不同的数据库管理系统提供不同的数据库语言。关系数据库管理系统几乎都提供关系数据库标准语言——SQL。

SQL 的全称是Structured Query Language,即结构化查询语言。SQL语句可以从关系数据库中获得数据,也可以建立数据库、增加数据、修改数据。1986年ANSI采用SQL语言作为关系数据库系统的标准语言,后被国际化标准组织(ISO)采纳为国际标准。SQL语言使用方便、功能丰富、简洁易学,是操作数据库的工业标准语言,得到广泛地应用。例如关系数据库产品DB

2、ORACLE等都实现了SQL语言。同时,其它数据库产品厂家也纷纷推出各自的支持SQL的软件或者与SQL的接口软件。这样SQL语言很快被整个计算机界认可。

SQL语言是一种非过程化语言,它一次处理一个记录集合,对数据提供自动导航。SQL语言允许用户在高层的数据结构上工作,而不对单个记录进行操作。SQL语言不要求用户指定数据的存取方法,而是使用查询优化器,由系统决定对指定数据存取的最快速手段。当设计者在关系表上定义了索引时,系统会自动利用索引进行快速检索,用户不需知道表上是否有索引或者有什么类型的索引等细节。

SQL语言可以完成许多功能,例如: ● 查询数据

● 在数据库表格中插入、修改和删除记录 ● 建立、修改和删除数据对象 ● 控制对数据和数据对象的存取 ● 确保数据库的一致性和完整性等 2.3.2 SQL查询

数据查询是关系运算理论在SQL语言中的主要体现,SELECT 语句是SQL查询的基本语句,当我们在对一个数据库进各种各样的操作时,使用的最多的就是数据查询,在以SQL为基础的关系数据库中,使用的最多的就是SELECT查询语句。 SELECT语句的完整句法如下: SELECT 目标表的列名或列表达式序列 FROM 基本表和(或)视图序列 [WHERE 行条件表达式] [GROUP BY 列名序列] [HAVING 组条件表达式] [ORDER BY列名 [ASC│DEAC]„]

我在SELECT语句中还使用了大量的保留字和通配符以进行各种各样的条件查询。在系统中有大量的查询按钮,其使用了大量的查询语句,而且这些查询语句大部分使用的是模糊查询,所以大量的使用了模式匹配符LIKE(判断值是否与指定的字符通配格式相符)。在包含LIKE的查询语句中可以使用两个通配符:%(百分号):与零个或多个字符组成的字符串匹配;_(下划线):与单个字符匹配。系统中的条件判断往往包含多个条件,这时就需要使用逻辑运算符NOT、AND、OR(用于多条件的逻辑连接),谓词ALL以及保留字DISTINCT等等。做为SELECT语句还有很多的使用方法,这里就不再叙述。 2.3.3 SQL数据更新

使用数据库的目的是为了有效地管理数据,而数据的插入、删除和修改则是必不可少的一个功能。在本系统中就大量地使用了数据插入、删除和修改这三种操作,现做一个简单地介绍。 ●数据插入

往数据库的基本表中插入数据使用的是INSERT语句,其方式有两种:一种是元组值的插入,另一种是查询结果的插入。在本系统中使用的是前一种方式,其句法如下: INSERT INTO 基本表名(列表名)VALUES(元组值) ●数据删除

往数据库的基本表中删除数据使用的是DELETE语句,其句法如下: DELETE FROM 基本表名 [WHERE 条件表达式] 在些作一点说明,删除语句实际上是“SELECT * FROM 基本表名 [WHERE 条件表达式]”和DELETE操作的结合,每找到一个元组,就把它删除。此外,DELETE语句只能从一个基本表中删除元组,WHERE子句中条件可以嵌套,也可以是来自几个基本表的复合条件。 ●数据修改

当需要修改基本表中元组的某些列值时,可以用UPDATE语句实现,其句法如下: UPDATE基本表名

SET列名=值表达式[,列名=值表达式„] [WHERE条件表达式] 在Delphi中使用SQL语句是很方便的,一般来说,都是通过TQuery组件来使用SQL语言的。有一点要进行说明,虽然通过TQuery组件来使用SQL语言很方便,但考虑到自己对不同组件的理解程度、个人习惯以及其它各个方面,在本系统中我采用的是ADO组件来对数据库进行操作。最简单的方法比如在TADOQuery组件的SQL属性中就可以键入SQL语句,至于详细的使用方法在后面进行介绍。

第三章 数据库开发工具 §3.1 Delphi 6.0 简介

Delphi类可以粗略地分成两部分:一部分是组件类,这些组件类通常以某种方式出现在组件面板上,当用户从组件面板上点取一个类的图标后,在程序中就自动生成了该类的对象(非可视组件除外);另一部分是功能类,这此功能类的对象通常出现在程序代码中,起着不可代替的作用,但是这些功能类在组件面板上是找不到的。在Delphi中,每一个类的祖先都是Tobject类,整个类的层次结构就像一棵倒挂的树,在最顶层的树根即为Tobject类。这样,按照面向对象编程的基本思想,就使得用户可用Tobject类这个类型代替任何其它类的数据类型。实际上在Delphi的类库中,Tobject类派生出了为数相当众多的子类,它们形成了一个庞大的体系,通常情况下,如果不自行开发组件,就不必了解整个类的体系结构,只用到类层次树的叶结点就足够了。 凡是做过程序开发的人都知道从来没有单纯的数据应用程序,也就是说,数据库应用程序必须和用户界面(可以是图形界面,也可以是命令接口)元素相结合,只讲界面或只讲数据库本身都构不成数据库应用程序,因而用Delphi 6.0开发数据库应用程序就隐含着界面开发。Delphi6中的VCL组件可用图3-1来说明。组件在Delphi程序的开发中是最显眼的角色。大家知道,在编写程序时一般都开始于在组件面板上选择组件并定义组件间的相互作用。但也有一些组件不在组件面板上,例如Tform和Tapplication(典型的非可视组件)。组件是Tcomponents派生出来的子类,可以流的形式存放在DFM文件中,具有事件和Publish属性。

窗口组件类是窗口化的可视化组件类,在Delphi的类库中占有最大的份额。在实际编程中,窗口组件类的对象都有句柄,可以接受输入焦点和包含其它组件。

图形组件与窗口组件并列,是另一大类组件。图形组件不是基于窗口的,因而不能有窗口句柄,不能接受输入焦点和包含其它组件。从图8-43中可以看出,图形组件的基类是TgraphicControl,在实际编程中,它们必须寄生于它们的宿主——窗口组件类的对象,由它们的拥有者负责其显示,而且它们还能触发一些和鼠标活动相关的事件。图形控件最典型的例子是Tlabel和TspeedButton。由此可以看出图形组件的功能很弱,有读者会问图形组件的用处何在呢?其实使用图形组件的最大好处在于节省资源,正是因为它们的功能较弱,所以使用的系统资源就要少。在一个应用程序中,如果能在不影响其功能的前提下合理大量地使用图形组件,将会大减少程序对系统资源的消耗。

非可视组件是与可视组件相并列的另一类组件,非可视组件在程序运行中是不可见的(除各种对话框组件之外,事实上有人认为对话框组件不能归入非可视组件,应该是另一种介于可视与非可视之间的组件)。 §3.2 Delphi 6.0 控件

用Delphi6开发数据库应用,重点是和各种数据库组件打交道,当然也要使用其它的一些组件,现在就我在系统设计中所使用的重要组件给与简单介绍。 3.2.1 ADO数据访问组件

ADO数据对象(Active Data Objects)实际是一种提供访问各种数据类型的链接机制。ADO设计为一种极简单的格式,通过ODBC的方法同数据库接口中,可以使用任何一种ODBC数据源,即不止适合于SQL Server、Oracle、Access等数据库应用程序,也适合于Excel表格、文本文件、图形文件和无格式的数据文件。ADO是基于OLE-DB之上的技术,因此ADO通过其内部的属性和方法提供统一的数据访问接口方法。ADO使您的客户端应用程序能够通过OLE DB提供访问和操作在数据库服务器中的数据。ADO支持用于建立C/S和Web的应用程序的主要功能。其主要优点是易于使用、高速度、低内存支出和占用磁盘空间较少。ADO同时具有远程数据服务(RDS)功能,通过RDS可以在一次往返过程中实现将数据从服务器移动到客户端应用程序和Web页、在客户端对数据进行处然后将更新结果返回服务器的操作。

Delphi 6.0继续对Microsoft的ADO访问能力的支持。这种能力是通过一组新组件实现的,这些组件是在企业版的ADO组件页中,在组件面版的ADO页上可以找到这些组件。利用在前面章节提到的TdataSet抽象类,ADO组件可以不通过BDE而直接实现ADO连接。这意味着只需要很少的代码就可以实现该连接并且性能得到提高。

利用ADO数据访问组件,可以只使用ADO结构与数据库取得联系并对其中的数据进行操作,而在这些过程中完全不需要使用BDE。大多数的ADO连接和数据集组件都是与基于BDE的连接和数据集组件相类似的。TADOConnection组件与基于BDE的应用程序中的Tdatabase组件类似。TADOTable与Ttable,TADOQuery与Tquery,以及TADOStoreProc和TstoredProc之间都具有这种类似的对应关系。使用这些ADO组件的方式与我们常使用的数据访问组件(基于BDE)都有许多相同之处。TTADODataSet没有直接的BDE对应组件,但它提供了许多与Ttable和Tquery相同的功能。同样,TADOCommand也没有相对应的BDE组件,它是在Delphi/ADO环境中完成特定功能的组件。Delphi 6.0通过ADO数据集访问组件,可以不借助BDE数据引擎而是通过微软的OLEDB来访问更为广泛的数据库中的数据。ADO数据集访问组件与常用的数据访问组件是并列的关系。

在系统中我主要使用的是ADOTablet和ADOQuery两个组件。 3.2.2 数据控制类DataControl 数据控制类负责数据库数据的显示,并把用户对数据的修改传回。这里的绝大多数组件,如DBText, DBEdit, DBMemo, DBImage, DBListBox, DBComboBox, DBCheckBox, DBRadioGroup, DBLookupListBox, DBLookupCombox, DBCtrGrid的功能和对应的非数据感知组件相同,如TEdit框,TRadioGroups单选按钮组等,只不过在显示数据库数据时要用而已。 在系统中主要使用数据网格控件DBGrid和数据库导航器控件DBNavigator。 3.2.3 数据访问类DataAccess 数据库应用系统中数据访问是一个首要问题,包括单用户和 C/S系统,都必须联系一些数据库和数据表文件。Delphi 6 提供了专门用于数据访问的基类控件。主要包括数据源控件DataSource、客户数据集控件ClientDataSet、数据集提供器控件DataSetProvider等等。

Tdatabase:当一个基于BDE的数据库应用程序需要一个永久数据库连接时,需要定制向一个数据库服务器的连接时,需要事务控制和特殊的数据库别名时就得用到Tdatabase对象。特别是当连接到一个远程的SQL数据库服务器时,如果要利用BDE进行数据库事务处理,那么,TDatabase对象的威力就体现出来了。在一个应用程序中为每一个数据库连接显示的声明Tdatabase对象要根据需要而定,不是必需的。对一个数据库连接,如果没有显示的声明并实例化TDatabase对象,系统就会产生一个带有默认属性的TDatabase对象。

TdataSource对象用于在DataSet对象(包括Tquery,TstoredProc,Ttable等)和数据感知组件之间提供一个连接的纽带,以便在窗体上显示数据库中的数据,在数据库中导航定位与编辑数据集中的数据。如果一个DataSet对象中的数据想在数据感知组件中显示和修改,它就必须和TdataSource对象相联系。同样,一个数据感知组件如果想和数据源相联系以便显示和操纵数据,就必须以TDataSource对象为中介。

用Delphi6作数据库应用开发概括来说如下:先利用数据存取组件和实际的数据库建立连接,并用Tsession对象和Tdatabase对象管理这些连接。然后以Tdatasource对象为中介,用数据感知组件向用户显示数据库的内容并接受用户的查询和修改等操作。 3.2.4 SQL语言在Delphi中的应用

在Delphi中使用SQL语言非常方便,一般来说,都是通过Tquery组件来使用SQL语言的。可以在TQuery组件的SQL属性中设置SQL语句。设计程序时,在该组件的属性对话框中选择SQL属性,单击带省略号的按钮,就可以打开String List Editor对话框,然后我们就可以在对话框中添加SQL语句。还可以使用Delphi的SQL Builder来自动生成SQL语句,这样可以避免手工编写SQL而可能造成的语法错误。

静态SQL语句在程序设计时便已固定下来,它不包含任何参数和变量。

动态SQL语句,也被称作参数化的语句,在其中间包含着表示字段名或表名的参数,例如下面的语句是一条动态SQL语句:

Select * From Students Where StudentCode =: StudentCode; 其中的变量StudentCode便是一个参数变量,它由一个冒号引导,在程序运行过程中,必须要为该参数赋值,该条SQL语句才能正确执行,每次运行应用程序时可以为该参数变量赋予不同的值。为参数赋值有三种方法:

①根据参数在SQL语句中出现的顺序,设置TQuery部件的Params属性值为参数赋值。 ②直接根据SQL语句中各参数的名字,调用ParamByName方法来为各参数赋值。

③将TQuery部件的DataSource属性设置为另一个数据源,这样将另一个数据源中与当前TQuery部件的SQL语句中的参数名相匹配的字段值赋给其对应的参数。利用这种方法也能实现所谓的连接查询,创建主要—明细型数据库应用。

在程序运行过程中,要想设置TQuery部件的SQL属性,必须首先调用Close方法,关闭TQuery部件,然后再调用Clear方法清除SQL属性中现存的SQL命令语句, 最后再调用Add方法为SQL属性设置新的SQL命令语句。例如: Query1.Close {关闭Query1) Query1.SQL.Clear {清除SQL属性中的SQL命令语句} Query1.SQL.Add(„Select * From Students„); Query1.SQL.Add(„ Where Name ="Lucy" „);

在为TQuery部件设置SQL属性时调用Close方法总是很安全的,如果TQuery部件已经被关闭了,调用Close方法时不会产生任何影响。在应用程序中为SQL属性设置新的SQL 命令语句时,必须要调用Clear方法以清除SQL属性中现存的SQL命令语句,如果不调用Clear方法,便调用Add方法向SQL属性中设置SQL命令语句,那么新设置的SQL命令语句会追加在现存SQL命令语句后面, 在程序运行时常常会出现出乎意料的查询结果甚至程序无法运行下去。 在这里要特别注意的,一般情况下TQuery部件的SQL属性只能包含一条完整的SQL语句,它不允许被设置成多条SQL语句。当然有些数据库服务器也支持在TQuery部件的SQL属性中设置多条SQL语句,只要数据库服务器允许这样,我们在编程时可以为 SQL 属性设置多条SQL语句。

在为TQuery部件设置完SQL属性的属性值之后,也即编写好适当的SQL程序之后,可以有多种方式来执行SQL程序。

在设计过程中,设置完TQuery部件的SQL属性之后将其Active属性的值置为True, 这样便可以执行SQL属性中的SQL程序,如果应用中有与TQuery部件相连的数据浏览部件( 如TDDGrid TDBEdit等)那么在这些数据浏览部件中会显示SQL程序的执行结果。

在应用程序运行过程中,通过程序调用TQuery部件的Open方法或ExecSQL 方法可以执行其SQL属性中的SQL程序。Open方法和ExecSQL方法是不一样的。Open方法只能用来执行SQL语言的查询语句(Select命令), 并返回一个查询结果集,而ExecSQL方法还可以用来执行其它常用的SQL语句(如INSERT, UPDATE, DELETE等命令),例如: Query1.Open (这样会返回一个查询结果集) 如果调用Open方法,而没有查询结果时,会出错。此时应该调用ExecSQL 方法来代替Open方法。如:

Query1.ExecSQL (没有返回结果) 当然在设计应用程序时,程序设计人员是无法确定TQuery部件中的SQL 语句是否会返回一个查询结果的。对于这种情况应当用Try…Except模块来设计程序。在 Try 部分调用Open方法,而在Except部分调用ExceSQL方法,这样才能保证程序的正确运行。

Delphi中用ADOQuery来使用SQL语句同样十分方便。在ADOQuery组件中首先通过ConnectionString属性值来联接数据源,然后就通过双击SQL…属性值来写入SQL语句。在Delphi中调用数据库,就可以调用ADOQuery组件,通过修改其中的SQL…属性中的SQL语句来实现对数据库的各项操作。

值得注意的是,ADOQuery组件只有在激活的情况下才可以被正确地使用,这样就提出了一个问题,也就是说,在每次修改ADOQuery组件的SQL…属性时都必须先行进行关闭,待清除掉SQL…中所有的SQL语句后才可以添加新的SQL语句。而且,在每一次修改完成以后,还应该记得重新将ADOQuery激活。其它的使用方法与TTQuery有许多的相似之处。 §3.3 Access 简介

建立一个数据库我们有多种选择,现在市场上有各种各样的数据库,而且每一种数据库都有其自身的特点,不能说哪一种更好,只能在其中寻找一种能更好地适应系统需求、更好地满足用户的要求以及适应开发人员的习惯。在本系统中,做为图书仓库管理系统是一个比较小的应用系统,它所产生和处理的数据量也比较小。因此,没有必要使用像SQL Server和Oracle这样的大型数据库。我首先想到的数据库是Borland公司的Paradox数据库。另外,Microsoft Office中的Access数据库在计算机上的应用比较普及,是开发小型数据库系统的比较理想的选择,所以,在本系统中我选择了Access数据库。

Access做为一个数据库管理系统,它被集成在Microsoft Office中。Access数据库处理的基本结构,采取关系型数据库模式。与其他的数据库系统相比,Access更加简单易学,一个普通的计算机用户可以很快地掌握它。Access 2000的功能十分强大,利用它可以方便地实现对信息保存、维护、查询、统计、打印、交流、发布,而且它可以十分方便地与Office其他组件交流数据,这些功能对一个一般用户而言已经足够了。 第四章 系统总体设计

软件系统的总体设计大约要经历可行性分析和项目开发计划,需求分析,概要设计,详细设计,编码,测试以及维护等七个阶段。可行性分析和项目开发计划在前面已经叙述,下面所要做的是进行软件需求分析,概要设计和详细设计。编码过程将在下一节论述,而测试和维护过程不在本文叙及。

§4.1 系统需求分析

在经过前一阶段的分析之后,我确定了我的开发课题为图书仓库管理。现在所要做的是要准确定义系统必须做什么以及系统必须具备的功能。

软件需求分析中我采用结构化分析方法(Structured Analysis,简称SA),SA是面向数据流进行需求分析的方法,像所有的软件分析方法(如面向对象分析方法、IDEF方法等等)一样,SA也是一种建模活动,它使用简单易读的符号,根据软件内部数据传递、变换的关系,自顶向下逐层分解,描绘满足功能要求的软件模型。

在系统中我采用数据流图(DFD)这种半形式化的描述方式表达需求。它是一种功能模型,以图形的方式描绘数据在系统中流动和处理的过程,只反映系统必须完成的逻辑功能。它有四种基本图形符号:

◆ →:箭头,表示数据流; ◆ 〇:圆或椭圆,表示加工; ◆ ═:双杠,表示数据存储;

◆ □:方框,表示数据的源点或终点。

为了表达较为复杂问题的数据处理过程,用一张数据流图是不够的,要按照问题的层次结构进行逐步分解,并以一套分层的数据流图反映这种结构关系。在这里我一共使用了三层数据流图,即顶层图,0层图和1层图(也是底层图)。

在多层数据流图中,顶层流图仅包含一个加工,它代表被开发系统,它的输入流是该系统的输入数据了,输出流是该系统的输出数据;底层流图是指其加工不需要再做分解的数据流图,中间层流图表示对其上层父图的细化,它的每一步加工可能继续细化成子图。 经过对系统的分析首先得到系统的顶层DFD,如下: 一步细化得到系统的0层DFD,如下:

再进一步细化每一个数据加工功能,得到系统的1层DFD图。

在这里只给出有关入库管理和出库管理的1层数据流图,它们是系统的关鍵部分,也是主要的部分。通过以上对数据流图的分析之后,我们已大体地了解了系统的功能和目标,接下来所要做的就是系统功能模块的划分和数据库的设计,也就是系统的概要设计。 §4.2 系统概要设计 在软件需求分析阶段,搞清楚了软件“做什么”的问题,形成了目标系统的逻辑模型。现在我们所要做的就是要把软件“做什么”的逻辑模型变换为“怎么做”的物理模型,即着手实现软件的需求。首先,我们需要描述的是系统的总的体系结构。 4.2.1 系统结构设计

系统的概要设计中最重要的就是系统的模块化。模块化是指解决一个复杂问题时自项向下逐层把软件系统划分成若干个模块的过程。每个模块完成一个特定的功能,所有的模块按某种方法组织起来,成为一个整体,完成整个系统所要求的功能。

将系统划分为多个模块是为了降低软件系统的复杂性,提高可读性、可维护性,但模块的划分不能是任意的,应尽量保持其独立性。也就是说,每个模块只完成系统要求的独立的子功能,并且与其他模块的联系最少且接口简单,即尽量做到高内聚低耦合,提高模块的独立性,为设计高质量的软件结构奠定基础。

在系统的概要设计中我采用结构化设计(Structure Design,简称SD),SD以需求分析阶段产生的数据流图DFD为基础,按一定的步骤映射成软件结构。我首先将整个系统化分为几个小问题,小模块,在系统中,我设计了用户管理、库存管理、入库管理、出库管理、员工管理和供应商管理6个小模块。然后,进一步细分模块,添加细节。比如,用户管理我又将其分为用户注册、用户注销、密码修改;库存管理分为库存记录查询、库存记录修改、库存记录打印等等。 以下就是系统的结构图:(在这里为了表达方便我将结构图分开来表达。)

在得到系统的第一层功能模块图后,经过进一步地细化,得一系统的子功能模块图: 4.2.2 数据库设计

在信息世界中,信息从客观事物出发流经数据库,通过决策机构最后又回到客观世界,信息的这一循环经历了三个领域:信息世界,数据世界,现实世界。现实世界的事物反映到人的头脑中,人的大脑对它有个认识过程,经过分析(选择、命名、分类等)进入信息世界。这些信息再进一步加工、编码,然后进数据世界,而软件系统的开发工作需要考虑这两个方面的问题,也就是要考虑系统开发所需要的数据,以及如何对这些数据进行操作。这两个问题贯穿了整个软件系统的开发过程,这也就是数据库的设计问题,软件设计的一个核心。 4.2.2.1 ER图设计

在系统设计的开始,我首先考虑的是如何用数据模型来数据库的结构与语义,以对现实世界进行抽象。目前广泛使用的数据模型可分为两种类型,一种是独立于计算机系统的“概念数据模型”,如“实体联系模型”;另一种是直接面向数据库逻辑结构的“结构数据模型”。在本系统中我采用“实体联系模型”(ER模型)来描述数据库的结构与语义,以对现实世界进行第一次抽象。ER模型直接从现实世界抽象出实体类型及实体间联系,然后用ER图来表示数据模型。它有两个明显的优点:接近于人的思维,容易理解;与计算机无关,用户容易接受。但ER模型只能说明实体间语义的联系,不能进一步说明详细的数据结构,它只是数据库设计的第一步。 ER图是直观表示概念模型的工具,它有四个基本成分: ◆ 矩形框,表示实体类型(考虑问题的对象)。 ◆ 菱形框,表示联系类型(实体间的联系)。

◆ 椭圆形框,表示实体类型和联系类型的属性。对于关键码的属性,在属性名下划一横线。 ◆直线,联系类型与其涉及的实体类型之间以直线连接。

本系统为图书仓库管理,主要管理图书的入库、出库以及库存等事项。仓库根据需要可以查询图书供应商的信息,同时还需要了解在入库和出库中员工的参与情况。依据仓库管理的实际情况,考虑了多方面的因素以后,确定系统的ER图如下:

(为了表达的方便,在这里我没有在一张图上表达出所有的关系,而是用一张总体ER图,和几张实体属性关系图来表达数据库的结构。)

在该数据库中,我设计了三个实体,分别是库存、员工和供应商以及两个联系类型入库和出库。在本系统中库存是核心,也是基本,没有了库存其它的也就没有什么意义了。员工记录的添加是考虑到责任问题,也就是说,在仓库管理的实际运用中,出现了责任不清的现象,特别是由于仓库的进出图书数量都比较大时产生了一系列问题,所以在设计数据库时,我特别考虑到这一点,加入了员工记录这一实体。供应商信息的添加主要出于对图书来源问题的思考。通过添加供应商信息可以比较清楚地了解图书的进货渠道,从图书的质量到供应商的信誉都可以进行了解,同时可以为以后的图书进购提供一定有用的信息。

入库联系类型将库存信息、供应商信息和员工信息联系在一起,可以方便地实现三个实体之间的联接,而出库联系类型则将库存信息和员工信息较好地联接起,同时这两个联系类型又都具有各自特有的属性。

下面就是各实体及联系类型的属性图:(带#号的属性为关键字段)4.2.2.2 数据库表格设计 在完成系统的ER图之后,需要将ER模型转化为关系模型,也就是说,要设计出数据库所需要的表格。在这里,我选用的是关系数据库。因为关系数据库中的二维表格可以很清楚地描述数据之间的联系。

在这里不得不提到一个概念——范式。其实在上一节的ER图设计中,已经运用了范式的思想,不仅如此,在数据库的表格设计中更离不开范式的思想,它是数据库设计的基础,如果不注意这个问题将会导致一系列问题的出现。

我在系统中定义的表格都严格地按照范式的思想和要求去完成,数据库中的所有表格都达到了三范式的要求。根据系统ER图,针对本系统的特点,在对所搜集的数据进行规范化之后,定义了如下六张表格,分别是库存信息表,入库信息表,出库信息表,员工信息表,供应商信息表和密码信息表。通过对这六张表格的操作可以较好地完成系统设计的各项功能,六张表格之间有着不同程度的联系。(说明:在以下数据表中,K代表主键,#代表外键,字段值不为空。) BookRecord 表(库存信息表)

字段名称 数据类型 说明 K BookID 数字 图书编号 BookName 文本 图书名 Author 文本 作者 Publisher 文本 出版社 PubDate 日期/时间 出版日期 Price 货币 价格 BookType 文本 图书类型 Number1 数字 库存数量 Addation 文本 备注 图4.13 库存信息表

库存信息表主要用于记录仓库中现存放的所有图书的详细信息,包括图书编号、书名、作者、出版社、图书类型等有关图书的各类信息,它即是该数据库的主表,也是系统主界面的主要内容。 在该表中图书编号是主键,它按图书入库的先后次序来编写,每当有图书入库,系统自动给出图书编号,这样我们按图书编号来查找图书是比较方便的。考虑到编号比较难于记忆,所以使用了出版社和图书类型两个字段,在系统中我提供了出版社和图书类型的分类查找,而且全部采用自动生成,每当系统中有新的出版社类型和图书类型,弹出菜单会自动添中新类型,这样就可以比较方便地实现按出版社和按图书类型查找。此外,库存数量也是一个比较关键的字段,该字段是在系统初始化时就给定的,每当有图书入库或出库操作,系统就会自动修改图书的库存数量,以保持数据的一致性。做为备注有一点说明,我的数据库中备注的数据类型是文本,而不是备注类型,主要考虑到该字段的长度并不大,而且在Delphi中文本数据类型的处理也比较方便一点。 Employee 表(员工信息表)

字段名称 数据类型 说明 K EmployeeID 数字 员工编号 EmployeeName 文本 员工姓名 Sex 文本 性别

BornDate 日期/时间 出生日期 Grade 文本 职称

WorkDate 日期/时间 工作日期 Telephone 文本 联系电话 Address 文本 联系地址

图4.14 员工信息表

员工信息表主要用于记录有关员工的各类信息,包括姓名、职称、出生日期、联系电话、联系地址等。它主要用来为系统提供员工的有关信息,因为在系统中,入库和出库操作均与员工有着一定的联系,在查询入库信息和出库信息时,有时需要查找有关此项记录有关的员工信息,在系统中我是通过入库记录与员工记录(出库记录和员工记录)之间的联接查询来完成的。另外,作为一个仓库也有必要了解其所属员工的一些基本情况,以便查询。 Shopkeeper 表(供应商信息表)

字段名称 数据类型 说明 K ShopkeeperID 数字 供应商编号 ShopkeeperName 文本 供应商姓名 Address 文本 地址 PostNo 数字 邮编

OfficePhone 文本 办公电话 HomePhone 文本 住宅电话 Email 文本 E-mail PayType 文本 付款方式

图4.15 供应商信息表

供应商信息表主要用于记录有关供应商的各类信息,包括姓名、地址、电话、付款方式等。它主要用来为系统提供供应商的有关信息,在系统中入库记录是与供应商记录相联系的,通过入库记录可以查找相关的供应商信息。在供应商信息中,考虑当实际情况,我特别加入了Email和付款方式这两个字段,因为在当今信息世界中,多种多样的通讯方式和多种多样的付款方式是必然的,是数据库中必须与以记录。

InRecord 表(入库信息表)

字段名称 数据类型 说明 K InID 数字 入库编号 # BookID 数字 图书编号 # EmployeeID 数字 员工编号 # ShopkeeperID 数字 供应商编号 Number 数字 入库数量 BuyDate 日期/时间 入库日期

图4.16 入库信息表

OutRecord 表(出库信息表)

字段名称 数据类型 说明 K OutID 数字 出库编号 # BookID 数字 图书编号 # EmployeeID 数字 员工编号 Number2 数字 出库数量 OutDate 日期/时间 出库日期 图4.17 出库信息表

入库信息表主要用于记录有关入库的详细信息,包括入库数量、入库日期以及图书、员工、供应商三方的编号,以便查询。出库信息表主要用于记录有关出库的详细信息,包括出库数量、出库日期以及图书、员工的编号。出库信息表和入库信息表一样,其实它们都属于联系类型,系统通过这两个表可以联接上其它的表为用户提供多种条件的联接查询。值得提出的一点是入库记录和出库记录的添加不仅仅是单表操作,由于它们都与库存记录相联系,所以,无论您是添中入库记录还是添加出库记录,都必须同时修改库存记录,以保持数据的一致性,否则将引发系统出错而这些我都让其在系统中自动完成。无论您是添加入库记录,还是添加出库记录,系统都将自动修改库存中图书的数量,而且,在您出库的数量大于库存数量时,系统还会自动提示错误,这样就可以防止一定错误的发生。

在入库信息表和出库信息表中我还定义了几个外键,它提供了一种表示几个关系联系的方法。比如,系统中通过在入库信息表中定义的外键 BookID、EmployeeID和ShopkeeperID可以将库存信息表、员工信息表和供应商信息表联系在一起,从而方便地实现联接查询,而且,引入外键的定义是实体完整性约束的一个主要方面。 Key 表(密码信息表)

字段名称 数据类型 说明 K KeyName 文本 用户姓名 KeyNo 文本 用户密码 图4.18 密码信息表

密码信息表主要用于记录所有的用户名和用户密码。它是在用户登陆时用来确定用户和密码的正确性,以防止非法用户登陆。 通过以上设计已经完成了系统的概要设计,当我们有了系统的功能模块图和数据库之后,就需要着手去实现每一个模块,为每一个功能设计程序流程图,这也就是系统的详细设计。 §4.3 系统详细设计

在前面的概要设计中,已将系统划分为多个模块,并将它们按照一定的原则组装起来,同时确定了每个功能及模块之间的外部接口。现在所要做的就是确定每个模块具体执行过程,也可以说是“过程设计”。

在处理过程设计时我采用的是结构化程序设计(简称SP)方法。需要指出的是系统的详细设计并不是指具体的编程序,而是将概要设计阶段产生的系统功能模块图细化成很容易产生程序的图纸。因此详细设计的结果基本决定了最终程序的质量。为软件的质量,延长软件的生存期,软件的可测试性、可维护性提供重要的保障。详细设计的目标不仅是逻辑上正确地实现每个模块的功能,还应使设计出的处理过程清晰易读。

由前一阶段产生的系统功能模块图,我为系统的主要部分设计了如下程序流程图:通过以上步骤,基本上完成了对整个系统的总体设计,接下来所要做的就是软件的编码工作。系统总体设计的好坏直接影响着下一步工作,只有在这一阶段设计出好的模块图和程序流程图,才能更有利于编码,产生好的软件系统。

第五章

系统应用程序设计 §5.1 系统窗体模块组成 §5.2 数据模块窗体的设置

在编写数据库应用程序时,经常要遇到这样的情况,即好多组件、窗体同时访问相同的数据源,如果为每一个组件或者窗体都设置一个数据源将是十分耗时的工件,而且要保证这些数据源的确是相同的也需花一番功夫。那么,能不能将这些数据源集中管理,最好是做成一个统一的模块,需要时就将该模块引入而不必直接操作数据源本身呢?数据模块(DataModule)是解决这个问题最好的答案。简单说来,数据模块是用来集中管理数据源的一个窗体,该窗体可被需要的地方随时引入。

图5.2给出了本程序的数据模块(datamoduleform)窗体图,除报表窗体外所有的数据存取组件和数据源组件都在此数据模块中进行了定义。值得一提的是,设置了数据库Database组件,该组件引入了系统所需的唯一的数据库tsxs,Database组件的DatabaseName属性设置为tsckgl。tsxs数据库已在ODBC配置程序中进行了设置。其他的数据存取组件都是基于此数据库组件创建的,这样做的好处是,当数据库的别名或者其他信息改变之后,只需修改Tdatabase组件的AliasName属性即可。

另外,在本系统的数据模块窗体图中,我大多采用的AODQuery组件而没有采用BDE组,这主要是基于对ADO组件的了解。在Delphi的学习中我对ADO组件了解的更加清楚,使用也较BDE更为熟练,而且,ADO组件的功能也较BDE更为强大,所以在这里大多采用ADO组件来进行数据库联接。同时我也使用了BDE组件中的Table,因为在某些时候BDE有着其自身特有的优越性。 主窗体功能模块的实现 file://主窗体程序代码

public

file://在程序的起始部分,定义快捷按钮点击事件 Procedure Popup1Handler(Sender:Tobject); Procedure Popup2Handler(Sender:TObject); ********************************************************************** procedure Tmainform.Popup1Handler(Sender: TObject); begin file://快捷按钮1(点“按出版社分类”按钮产生)的点击事件 with datamoduleform.MainQuery do

begin

file://打开数据模块窗体的MainQuery,对BookRecord表进行操作 close;

file://关闭MainQuery SQL.Clear;

file://清除SQL属性中的SQL命令语句

SQL.Add(„select * from BookRecord where Publisher=:Pub„); file://添加新的SQL语句 Parameters.ParamByName(„Pub„).Value:=(Sender as TMenuItem).Caption; open;

file://重新打开MainQuery end; end; ********************************************************************** procedure Tmainform.SpeedButton1Click(Sender: TObject); Var s1,s2,s3,s4,s5 :String;

file://设立5个变量以方便实现模糊查询 begin

file://主窗口库存查询按钮事件 with datamoduleform.MainQuery do begin close; SQL.Clear; SQL.Add(„select * from BookRecord„);

SQL.Add(„where BookID Like :BookID and BookName Like :Name and Author Like :Author and Publisher Like :pub and BookType Like :BookType„);

file://使用Like语句来实现模糊查询

if Edit1.Text<>„„ then s1:=„%„+Edit1.Text+„%„ else s1:=„%„;

Parameters.ParamByName(„BookID„).Value:=s1;

file://给变量s1赋值 if Edit2.Text<>„„ then s2:=„%„+Edit2.Text+„%„ else s2:=„%„;

Parameters.ParamByName(„Name„).Value:=s2;

file://给变量s2赋值 if Edit3.Text<>„„ then s3:=„%„+Edit3.Text+„%„ else s3:=„%„;

Parameters.ParamByName(„Author„).Value:=s3;

file://给变量s2赋值 if Edit4.Text<>„„ then s4:=„%„+Edit4.Text+„%„ else s4:=„%„;

Parameters.ParamByName(„Pub„).Value:=s4;

file://给变量s2赋值 if Edit5.Text <>„„ then s5:=„%„+Edit5.Text+„%„ else s5:=„%„;

Parameters.ParamByName(„BookType„).Value:=s5;

file://给变量s2赋值 open; if FieldValues[„BookID„]=NULL

file://判断是否找到记录 then begin Messagedlg(„没有找到你所需要的记录!„,mtInformation,[mbOK],0); Edit1.Text:=„„;Edit2.Text:=„„;Edit3.Text:=„„;Edit4.Text:=„„;Edit5.Text:=„„; close; SQL.Clear; SQL.Add(„select * from BookRecord„);

file://这里相当于一个刷新功能 open; end;end; end; ********************************************************************** procedure Tmainform.SpeedButton3Click(Sender: TObject); begin

file://库存表刷新按钮事件 with datamoduleform.MainQuery do begin close; SQL.Clear; SQL.Add(„select * from BookRecord„); open; end; end; ********************************************************************** procedure Tmainform.SpeedButton11Click(Sender: TObject); var PopupItem:TMenuItem; begin

file://自动生成快捷按钮1的内容 with datamoduleform.BookQuery do begin

file://从数据库中选择出版社类型 close; SQL.Clear; SQL.Add(„select distinct Publisher from BookRecord„); open; PopupMenu1:=TPopupMenu.Create(Self); file://自动生成快捷菜单 PopupMenu1.AutoHotkeys:=maManual; file://自定义热键 while Not Eof do begin

file://根据出版社内容生成菜单子项 PopupItem:=TMenuItem.Create(Self); PopupItem.Caption:=FieldByName(„Publisher„).AsString; PopupMenu1.Items.Add(PopupItem); PopupItem.onClick:=Popup1Handler;

file://确定菜单子项的点击事件 Next; end; end; PopupMenu1.Popup(384,67);

file://在指定位置显示快捷菜单1 end; ********************************************************************** procedure Tmainform.FormActivate(Sender: TObject); begin

file://系统初始化,在进入mainform时自动添加数据源 mainform.DBGrid1.DataSource:=datamoduleform.MainSource; mainform.DBNavigator1.DataSource:=datamoduleform.MainSource; mainform.DBGrid2.DataSource:=datamoduleform.EmpSource; mainform.DBNavigator2.DataSource:=datamoduleform.EmpSource; mainform.DBGrid3.DataSource:=datamoduleform.ShopSource; mainform.DBNavigator3.DataSource:=datamoduleform.ShopSource; mainform.DBGrid4.DataSource:=datamoduleform.InSource; mainform.DBNavigator4.DataSource:=datamoduleform.InSource; mainform.DBGrid5.DataSource:=datamoduleform.OutSource; mainform.DBNavigator5.DataSource:=datamoduleform.OutSource; end; ********************************************************************** procedure Tmainform.FormCreate(Sender: TObject); begin

file://系统初始化,定义界面大小,以适应不同分辩率 Width:=800;Height:=600; end; ********************************************************************** procedure Tmainform.Timer1Timer(Sender: TObject); begin

file://在状态栏显示时间

StatusBar1.Panels[2].Text:=DateToStr(Date); StatusBar1.Panels[4].Text:=TimeToStr(Time); end; §5.4 入库、出库窗体模块的实现

图5.4 系统入库管理窗体

图5.5 系统出库管理窗体

procedure Tinoutform.SpeedButton4Click(Sender: TObject); begin

file://入库管理查找按钮事件

with datamoduleform.BookQuery do file://入库查询处理

begin

close;

SQL.Clear;

SQL.Add(„select * from BookRecord where BookID=:BookID„);

Parameters.ParamByName(„BookID„).Value:=Edit13.Text;

open;

if FieldValues[„BookID„]<>NULL then begin

Edit1.Text:=„„;

Edit1.ReadOnly:=true;Edit1.Color:=clMenu;

Edit6.Text:=FieldValues[„BookName„]; file://显示图书名

Edit6.ReadOnly:=true;Edit6.Color:=clMenu; file://设置显示框不可更改属性

Edit7.Text:=FieldValues[„Author„];

Edit7.ReadOnly:=true;Edit7.Color:=clMenu;

Edit8.Text:=FieldValues[„Publisher„];

Edit8.ReadOnly:=true;Edit8.Color:=clMenu;

Edit9.Text:=FieldValues[„PubDate„];

Edit9.ReadOnly:=true;Edit9.Color:=clMenu;

Edit10.Text:=FieldValues[„Price„];

Edit10.ReadOnly:=true;Edit10.Color:=clMenu;

Edit11.Text:=FieldValues[„BookType„];

Edit11.ReadOnly:=true;Edit11.Color:=clMenu;

Edit12.Text:=FieldValues[„Number1„];

Edit12.ReadOnly:=true;Edit12.Color:=clMenu;

If FieldValues[„Addation„]<>NULL then Edit25.Text:=FieldValues[„Addation„]

else Edit25.Text:=„„;

Edit25.ReadOnly:=true;Edit25.Color:=clMenu;

end

else

begin file://在没有查找到的情况下,清空所有显示框

Edit1.ReadOnly:=false;Edit1.Text:=„„;Edit1.Color:=clMenu;

Edit6.ReadOnly:=false;Edit6.Text:=„„;Edit6.Color:=clMenu;

Edit7.ReadOnly:=false;Edit7.Text:=„„;Edit7.Color:=clMenu;

Edit8.ReadOnly:=false;Edit8.Text:=„„;Edit8.Color:=clMenu;

Edit9.ReadOnly:=false;Edit9.Text:=„„;Edit9.Color:=clMenu;

Edit10.ReadOnly:=false;Edit10.Text:=„„;Edit10.Color:=clMenu;

Edit11.ReadOnly:=false;Edit11.Text:=„„;Edit11.Color:=clMenu;

Edit12.ReadOnly:=false;Edit12.Text:=„„;Edit12.Color:=clMenu;

Edit25.ReadOnly:=false;Edit25.Text:=„„;Edit25.Color:=clMenu;

MessageDlg(„没有找到你所需要的记录!„,mtInformation,[mbOK],0);

Edit13.Text:=„„;Edit13.SetFocus;

end; end; with datamoduleform.InQuery do file://自动入库编号的获取

begin

close;

SQL.Clear;

SQL.Add(„select * from InRecord where InID>=All(select InID from InRecord)„);

open;

file://找到入库编号中最大的一个

Edit26.ReadOnly:=false;

Edit26.Text:=FieldValues[„InID„]+1; file://最大的入库编号加1形成新的入库编号

Edit26.ReadOnly:=true;Edit26.Color:=clMenu; file://设置编号的不可更改性

end; end; ********************************************************************** procedure Tinoutform.SpeedButton1Click(Sender: TObject); var s:integer; begin file://入库管理添加按钮事件

if Edit1.Text<>NULL then MessageDlg(„请输入完整的入库信息和图书信息,然后单击确定按钮。„, mtInformation,[mbok],0) else begin

if (Edit2.Text=„„) or (Edit3.Text=„„) or (Edit4.Text=„„) or (Edit5.Text=„„)

then begin

MessageDlg(„请输入完整的入库信息!„,mtInformation,[mbok],0);

Edit2.SetFocus;

end

else begin

with datamoduleform.InQuery do file://将找到的图书信息显示

begin

close;

SQL.Clear; SQL.Add(„insert into InRecord values(:InID,:BookID,:EmpID,:ShopID, :Number,:InDate)„); file://向入库信息表中插入记录

Parameters.ParamByName(„InID„).Value:=Edit26.Text; file://向Edit框取值

Parameters.ParamByName(„BookID„).Value:=Edit13.Text;

Parameters.ParamByName(„EmpID„).Value:=Edit2.Text;

Parameters.ParamByName(„ShopID„).Value:=Edit3.Text;

Parameters.ParamByName(„Number„).Value:=Edit4.Text;

Parameters.ParamByName(„InDate„).Value:=Edit5.Text;

execSQL;

end;

Edit12.ReadOnly:=False;

S:=StrToInt(Edit12.Text)+StrToInt(Edit4.Text); file://计算入库后库存图书数量

Edit12.Text:=IntToStr(s); file://将修改后的库存图书数量显示

Edit12.ReadOnly:=true;

with datamoduleform.BookQuery do

file://修改库存记录中图书数量

begin

close;

SQL.Clear;

SQL.Add(„update BookRecord set Number1=:Number where BookID=:BookID„);

Parameters.ParamByName(„Number„).Value:=s;

Parameters.ParamByName(„BookID„).Value:=Edit13.Text;

execSQL;

file://提交SQL语句

MessageDlg(„记录已成功添加!„,mtInformation,[mbOK],0);

Edit13.SetFocus;

end;

end; end; end; ********************************************************************** procedure Tinoutform.SpeedButton2Click(Sender: TObject); begin

file://入库管理确定按钮事件

if (Edit2.Text=„„) or (Edit3.Text=„„) or (Edit4.Text=„„) or (Edit5.Text=„„)

or (Edit6.Text=„„) or (Edit7.Text=„„) or (Edit8.Text=„„) or (Edit9.Text=„„)

or (Edit10.Text=„„) or (Edit11.Text=„„) or (Edit25.Text=„„)

then begin file://判断输入信息的完整性

MessageDlg(„请输入所需的全部入库信息!„,mtInformation,[mbok],0); Edit2.SetFocus; end else begin

with datamoduleform.InQuery do file://入库信息添加

begin

close;

SQL.Clear; SQL.Add(„insert into InRecord values(:InID,:BookID,:EmpID,:ShopID, :Number,:InDate)„);

file://向入库信息表中插入记录

Parameters.ParamByName(„InID„).Value:=Edit26.Text;

Parameters.ParamByName(„BookID„).Value:=Edit1.Text;

Parameters.ParamByName(„EmpID„).Value:=Edit2.Text;

Parameters.ParamByName(„ShopID„).Value:=Edit3.Text;

Parameters.ParamByName(„Number„).Value:=Edit4.Text;

Parameters.ParamByName(„InDate„).Value:=Edit5.Text;

execSQL;

end;

with datamoduleform.BookQuery do

begin

close;

SQL.Clear;

file://在完成入库信息的添加后,修改库存记录 SQL.Add(„insert into BookRecord values(:BookID,:BookName,:Author, :Publisher,:PubDate,:Price,:BookType,:Number,:Addration)„);

Parameters.ParamByName(„BookID„).Value:=Edit1.Text;

Parameters.ParamByName(„BookName„).Value:=Edit6.Text;

Parameters.ParamByName(„Author„).Value:=Edit7.Text;

Parameters.ParamByName(„Publisher„).Value:=Edit8.Text;

Parameters.ParamByName(„PubDate„).Value:=Edit9.Text;

Parameters.ParamByName(„Price„).Value:=Edit10.Text;

Parameters.ParamByName(„BookType„).Value:=Edit11.Text;

Parameters.ParamByName(„Number„).Value:=Edit4.Text;

Parameters.ParamByName(„Addration„).Value:=Edit25.Text;

execSQL;

end;

MessageDlg(„记录添加成功!„,mtInformation,[mbok],0);

end; end; ********************************************************************** procedure Tinoutform.SpeedButton11Click(Sender: TObject); begin file://新书入库按钮事件

Edit13.Text:=„„;Edit13.Color:=clMenu; with datamoduleform.InQuery do file://自动入库编号的获取

begin close; SQL.Clear; SQL.Add(„select * from InRecord where InID>=All(select InID from InRecord)„);

open; Edit26.Text:=FieldValues[„InID„]+1;

Edit26.ReadOnly:=true;Edit26.Color:=clMenu; end; with datamoduleform.BookQuery do file://自动图书编号的获取

begin close;

SQL.Clear;

SQL.Add(„select * from BookRecord where BookID>=All(select BookRecord)„);

file://找到库存图书编号中最大的一个

open;

Edit1.ReadOnly:=false;

Edit1.Text:=FieldValues[„BookID„]+1; file://显示自动生成的图书编号

Edit1.ReadOnly:=true;Edit1.Color:=clMenu; end; Edit2.Text:=„„;Edit3.Text:=„„;Edit4.Text:=„„;Edit5.Text:=„„;

Edit6.ReadOnly:=false;Edit6.Text:=„„;Edit6.Color:=clWindow;

Edit7.ReadOnly:=false;Edit7.Text:=„„;Edit7.Color:=clWindow;

Edit8.ReadOnly:=false;Edit8.Text:=„„;Edit8.Color:=clWindow;

Edit9.ReadOnly:=false;Edit9.Text:=„„;Edit9.Color:=clWindow;

Edit10.ReadOnly:=false;Edit10.Text:=„„;Edit10.Color:=clWindow;

Edit11.ReadOnly:=false;Edit11.Text:=„„;Edit11.Color:=clWindow;

Edit12.ReadOnly:=false;Edit12.Text:=„„;Edit12.Color:=clMenu;

Edit25.ReadOnly:=false;Edit25.Text:=„„;Edit25.Color:=clWindow; end; procedure Tinoutform.SpeedButton22Click(Sender: TObject); var s:integer; begin file://出库管理确定按钮事件

if (Edit24.Text=„„) or (Edit27.Text=„„) or (Edit28.Text=„„) then begin MessageDlg(„请输入完整的出库信息!„,mtInformation,[mbok],0); Edit24.SetFocus; end else begin if Edit27.Text>Edit21.Text file://检查出库数量是否小于库存数量 then begin MessageDlg(„库存中的图书数量不够!„,mtInformation,[mbok],0); Edit27.Text:=„„;Edit27.SetFocus;

end else begin with datamoduleform.OutQuery do begin

BookID from close; SQL.Clear; SQL.Add(„insert into OutRecord values(:OutID,:BookID,:EmpID, :Number,:OutTime)„); file://添加出库记录

Parameters.ParamByName(„OutID„).Value:=Edit23.Text; Parameters.ParamByName(„BookID„).Value:=Edit14.Text; Parameters.ParamByName(„EmpID„).Value:=Edit24.Text; Parameters.ParamByName(„Number„).Value:=Edit27.Text; Parameters.ParamByName(„OutTime„).Value:=Edit28.Text; execSQL; end; Edit21.ReadOnly:=False; s:=StrToInt(Edit21.Text)-StrToInt(Edit27.Text); file://计算出库后库存图书数量 Edit21.Text:=IntToStr(s); file://显示出库后库存图书数量 Edit21.ReadOnly:=True; with datamoduleform.BookQuery do begin

file://修改库存图书数量 close; SQL.Clear; SQL.Add(„update BookRecord set Number1=:Number where BookID=:BookID„); Parameters.ParamByName(„Number„).Value:=s;

Parameters.ParamByName(„BookID„).Value:=Edit14.Text; execSQL; end; MessageDlg(„出库记录添加成功!„,mtInformation,[mbok],0); Edit14.Text:=„„;Edit14.SetFocus; end; end; end;

§5.5 查询功能的实现

查询功能包括员工信息查询,供应商信息查询,入库信息查询和出库信息查询。由于每一个功能的实现都差不太多,而且其窗体也差不太多,所以在这里只给出员工信息查询窗体及其源代码。

图5.6 员工信息查询窗体

procedure Tfindempform.SpeedButton1Click(Sender: TObject); Var s1,s2,s3 :String; begin

file://员工记录查询窗体查找按钮事件 with datamoduleform.EmpQuery do begin close; SQL.Clear; SQL.Add(„select * from Employee„);

SQL.Add(„where EmployeeID Like :EmpID and EmployeeName Like :Name and Grade Like :Grade„);

file://实现模糊查询功能

if Edit1.Text<>„„ then s1:=„%„+Edit1.Text+„%„ else s1:=„%„; Parameters.ParamByName(„EmpID„).Value:=s1;

if Edit2.Text<>„„ then s2:=„%„+Edit2.Text+„%„ else s2:=„%„; Parameters.ParamByName(„Name„).Value:=s2;

if Edit3.Text<>„„ then s3:=„%„+Edit3.Text+„%„ else s3:=„%„; Parameters.ParamByName(„Grade„).Value:=s3; open; if FieldValues[„EmployeeID„]<>NULL

then findempform.Close

file://在找到记录的情况下关闭查找窗口 else begin MessageDlg(„没有找到你所需要的记录!„,mtInformation,[mbOK],0); Edit1.Text:=„„;Edit2.Text:=„„;Edit3.Text:=„„;Edit1.SetFocus; close; SQL.Clear; SQL.Add(„select * from Employee„); file://刷新员工信息窗口 open; end; end; end; §5.6 系统登陆窗体模块的实现

由于系统登陆窗体中有一幅彩图,在这里不便给出,而只给出了系统的实现。 var keyname: string; file://定义了一个全局变量,在key2中有调用 procedure Tkeyform.SpeedButton1Click(Sender: TObject); var s:string;

file://登陆窗口登陆按钮事件 begin if (Edit1.Text=„„) then begin MessageDlg(„清输入登陆姓名和密码!„,mtInformation,[mbok],0); Edit1.SetFocus; end else begin datamoduleform.KeyTable.Active:=true; if not datamoduleform.KeyTable.Locate(„KeyName„,Edit1.Text,[])

file://判断登陆名是否存在 then begin MessageDlg(„登陆名错误,请重新输入!„,mtInformation,[mbok],0); Edit1.Text:=„„; Edit1.SetFocus; end else begin with datamoduleform.KeyQuery do begin close; SQL.Clear; SQL.Add(„select * from Key where KeyName=:KeyName„); Parameters.ParamByName(„KeyName„).Value:=Edit1.Text; open; s:=FieldValues[„KeyNo„]; end; if s<>Edit2.Text file://判断登陆密码是否正确 then begin MessageDlg(„登陆密码错误,请重新输入!„,mtInformation,[mbok],0); Edit2.Text:=„„; Edit2.SetFocus; end else begin keyname:=Edit1.Text; keyform.Hide; mainform.Show;mainform.WindowState:=wsMaximized; end; end; end; end; §5.7 用户管理功能的实现 5.7.1 用户管理主窗体

图5.7 用户管理主窗体 5.7.2 密码修改窗体模块的实现

图5.8 密码修改窗体

procedure Tkey2form.SpeedButton1Click(Sender: TObject); begin file://密码修改窗口修改按钮事件 if (Edit1.Text=„„)or(Edit2.Text=„„)or(Edit3.Text=„„) then begin MessageDlg(„请输入完整的信息。„,mtInformation,[mbok],0); Edit1.SetFocus; end else begin if Not datamoduleform.KeyTable.Locate(„KeyNo„,Edit1.Text,[]) then begin MessageDlg(„原密码输入错误,不能修改新密码!„,mtInformation,[mbok],0); Edit1.Text:=„„;Edit2.Text:=„„;Edit3.Text:=„„;Edit1.SetFocus; end else begin if Edit2.Text<>Edit3.Text then begin MessageDlg(„两次密码输入不同,请重新输入新密码!„,mtInformation,[mbok],0); Edit2.Text:=„„;Edit3.Text:=„„;Edit2.SetFocus; end else begin

file://在数据库中修改密码 with datamoduleform.KeyQuery do begin close; SQL.Clear; SQL.Add(„update key set KeyNo=:KeyNo where KeyName=:KeyName„); Parameters.ParamByName(„KeyName„).Value:=keyname; Parameters.ParamByName(„KeyNo„).Value:=Edit2.Text; execSQL; MessageDlg(„密码修改成功!„,mtInformation,[mbok],0); key2form.Close; end; end; end; end; end; 5.7.3 用户注册窗体模块的实现

图5.9 用户注册窗体

procedure Tkey3form.SpeedButton1Click(Sender: TObject); begin file://用户注删窗口注删按钮事件 if (Edit1.Text=„„)or(Edit2.Text=„„)or(Edit3.Text=„„) then begin MessageDlg(„请输入完整的信息!„,mtInformation,[mbok],0); Edit1.SetFocus; end else begin if datamoduleform.KeyTable.Locate(„KeyName„,Edit1.Text,[])

file://判断用户名是否存在,系统不允许用户名重复 then begin MessageDlg(„用户名已存在,请输入新的用户名和密码!„, mtInformation,[mbok],0); Edit1.Text:=„„;Edit2.Text:=„„;Edit3.Text:=„„;Edit1.SetFocus; end else begin if Edit2.Text<>Edit3.Text then begin MessageDlg(„您输入的两个密码不相同,请重新输入!„,mtInformation,[mbok],0); Edit2.Text:=„„;Edit3.Text:=„„;Edit2.SetFocus; end else begin with datamoduleform.KeyQuery do

file://在数据库中添加该用户 begin close; SQL.Clear; SQL.Add(„insert into Key values(:KeyName,:KeyNo)„); Parameters.ParamByName(„KeyName„).Value:=Edit1.Text; Parameters.ParamByName(„KeyNo„).Value:=Edit2.Text; execSQL; end; MessageDlg(„新用户添加成功,您可以继续添加用户,或按“取消”退出。„,mtInformation,[mbok],0);

Edit1.Text:=„„;Edit2.Text:=„„;Edit3.Text:=„„;Edit1.SetFocus; end; end; end; end; 5.7.4 用户注销窗体模块的实现

图5.10 用户注销窗体

procedure Tkey4form.SpeedButton1Click(Sender: TObject); var s:string; begin file://用户注销窗口注销按钮事件 if (Edit1.Text=„„)or(Edit2.Text=„„)

then MessageDlg(„请输入完整的信息!„,mtInformation,[mbok],0) else begin if Not datamoduleform.KeyTable.Locate(„KeyName„,Edit1.Text,[])

file://判断用户名是否存在,用户名必须存在,才可以删除 then begin MessageDlg(„您所输入的用户名不存在,请重新输入或按“取消”退出。„, mtInformation,[mbok],0); Edit1.Text:=„„;Edit2.Text:=„„;Edit1.SetFocus; end else begin with datamoduleform.KeyQuery do begin close; SQL.Clear; SQL.Add(„select * from Key where KeyName=:KeyName„); Parameters.ParamByName(„KeyName„).Value:=Edit1.Text; open; s:=FieldValues[„KeyNo„]; end; if s<>Edit2.Text file://判断该用户名下的密码是否正确 then begin MessageDlg(„您所输入的密码不正确,请重新输入或按“取消”退出。„, mtInformation,[mbok],0); Edit2.Text:=„„;Edit2.SetFocus; end else begin

file://从数据库中删除该用户 with datamoduleform.KeyQuery do begin close; SQL.Clear; SQL.Add(„delete from Key where KeyName=:KeyName„); Parameters.ParamByName(„KeyName„).Value:=Edit1.Text; execSQL; end; MessageDlg(„用户已成功删除,您可以继续删除用户,或按“取消”退出。„, mtInformation,[mbok],0); Edit1.Text:=„„;Edit2.Text:=„„;Edit1.SetFocus; end; end; end; end;

结束语

本系统是一个面向小型图书企业,具有一定实用性的数据库信息管理系统。它主要完成对图书仓库的一系列管理,包括入库、出库、库存以及员工和供应商信息管理。本系统采用当前流行的面向对象的开发工具—Delphi来完成整个系统的设计,在数据库的设计上利用了Access的便利性和实用性。

本系统具有相当的实用功能。在查询方面,系统实现了多条件任意字段的模糊查询,同时在分类查询上实现了动态生成,系统可以自动识别用户不同的输入。在图书入库、出库和库存三者之间建立了良好的链接关系,某一部分地修改均会自动引发系统对与其相关的部分进行连锁修改。在用户管理方面,系统较好地实现了用户注册,用户注销和密码修改等各项功能。 系统在设计过程中不可避免地遇到了各种各样的问题,由于整个系统完全都是由个人设计的,有关Delphi许多细节问题都要靠自己去摸索,加之本人水平有限,并没有完全地理解Delphi的强大功能,而且还存在着许多不足之处。如:

受开发条件和开发时间的限制,本系统只利用了本地数据库Access,它同应用程序处于同一系统中,能存储的数据量也有一定限制,并没有发挥出Delphi其数据库方面的优势; ※

报表打印功能尚不够全面完善,不能实现动态报表;

在一些数据输入时没有及时的进行数据格式校验,不能保证数据输入的绝对正确性。 ※

由于时间关系,系统功能实现不够完善,使用不是很方便,比如,没有实现多条记录的连锁删除和添加以及数据的导入功能。 这些都是需要完善的地方,该系统离实际使用也还有相当的距离,需要我进行不断地补充和完善。

通过本次毕业设计我学到了不少新的东西,也发现了大量的问题,有些在设计过程中已经解决,有些还有待今后慢慢学习。只要学习就会有更多的问题,有更多的难点,但也会有更多的收获。

考 文 献

[1] 郑荣贵、黄平、谷会东,Delphi 6.0数据库开发与应用,中科多媒体电子出版社,2002 [2] 伍俊良,Delphi 6控件应用实例教程,北京希望电子出版社,2002 [3] 卢国俊,Delphi 6数据库开发,电子工业出版社,2002 [4] 边萌,Delphi 编程起步,机械工业出版社,2002 [5] 伍俊良,Delphi 6课程设计案例精编,中国水利水电出版社,2002 [6] 丁宝康,数据库原理,经济科学出版社,2000 [7] 陆丽娜,软件工程,经济科学出版社,2000

第7篇:图书管理系统的数据库设计

摘要:虚拟为某公司建立的图书馆管理系统进行数据库设计,目的在于使该系统的运行能提高该公司的资料管理水平和现代化管理水平。本系统是一个中小型管理系统,运行环境是Windows2003 server,因此使用Windows环境下最容易使用且功能又比较强大的Microsoft SQL Server 2000 作为后台的数据库系统。??

关键词:图书管理系统;数据库;设计??

中图分类号:TP311.11文献标识码:A文章编号:1672-7800(2011)07-0164-02?お?

??

作者简介:刘定智(1976-),女,贵州贵阳人,贵州职业技术学院实验师,研究方向为算法设计,数据库。

0引言??

目前,国内大部分大型的公共图书馆和高校图书馆都实现了网络管理,中小型图书馆(包括企业图书馆),也在朝着这个方向发展。在本文中,我们虚拟为某公司建立的图书馆管理系统进行数据库设计,目的在于使该系统的运行能提高该公司的资料管理水平和现代化管理水平。本系统是一个中小型管理系统,运行环境是Windows2003 server,因此使用Windows环境下最容易使用且功能又比较强大的Microsoft SQL Server 2000 作为后台的数据库系统。??

1需求分析??

需求分析是数据库设计的重要工作,通过需求分析,对整个系统的主要需求描述如图1所示:??

图1数字图书馆系统(Use Case View)??

2数据库设计??

在图书管理系统中,数据库设计占重要位置,数据库设计质量的优劣,可直接影响到数据库数据的冗余度、数据的一致性、数据丢失等问题。下面就系统数据库规范化设计进行说明。??

2.1数据库设计的理论指导??

数据库设计的理论指导是范式理论,其主要内容如下:①如果关系模式R,其所有的域为单纯域则称R是规范化的关系,或称第一范式 (1NF);②如果关系模式R为第一范式,且每个非主属性完全函数依赖于码,则模式R为第二范式(2NF);③如果关系模式R为第二范式,且每个非主属性非传递依赖于码,则称关系模式R为第三范式(3NF);④关系模式R为第一范式,满足函数依赖集合F,X和A均为R的属性集合,且X不包含A,如果R满足X->A且X必包含R的码,称关系模式R为BCNF范式。??

2.2数据库设计??

图书管理系统数据库常常要设计含有如下数据项:借书证号、姓名、单位、馆藏号(馆藏号为每本书上的条形码号)、书名、分类号、作者、价格等。如何进行模式的设计呢?下面以图书流通模块所涉及的数据库为例来说明。??

先设计图书流通的实体-关系图(E-R图)。E-R图由3个相关联的部分构成,即实体、实体与实体之间的关系以及实体和关系的属性。图书流通过程中实体“图书”与“读者”之间的关系是借阅和被借阅的关系,实体“读者”与“单位”之间的关系是属于和被属于的关系,“图书”的属性有“馆藏号”、“书名”、“分类号”、“作者”、“价格”,“读者”的属性有“借书证号”、“姓名”、“性别”,“单位”的属性有“单位编号”和“单位名称”,“借阅”属性“借书日期”,由此得出E-R图如图2所示:??

图2图书流通的E-R??

从图中可以知道:①“借书证号”是唯一的,所以“借书证号”决定“姓名”,每位读者应只属于一个性别,所以“借书证号”也决定“性别”;②“馆藏号”是唯一的,所以“馆藏号”决定“书名”、“分类号”、“作者”、“价格”;③“单位编号”是唯一的,所以“单位编号”决定“单位名称”;④每位读者在一个时间只能借一本书,所以“借书证号” +“馆藏号”决定“借阅时间”。??

如果将这些数据项置于一个关系模式中,根据范式理论,该关系模式属于1NF(第一范式),它存在删除异常和冗余等问题,不是理想的模式,因此要把它分解成满足3NF或BCNF的关系模式。根据范式理论和E-R图转换成关系模型的规则,上面的E-R图可转换为4个关系模式:①图书(馆藏号、书名、分类号、作者、价格);②读者(借书证号、姓名、性别、单位编号);③借阅(借书证号、馆藏号、借阅时间),④单位(单位编码、单位名称),其中打下划线的为码,这样就解决了插入、删除和数据冗余等问题。??

我们对数据的结构进行详细的分析,按照上述的设计思想,共设计了读者表,书目表,馆藏表,流通表等百余张数据表,然后创建视图和存储过程。下面举例说明:①读者表:借书证号、姓名、单位、读者类别、职称等字段;②书目表:馆藏号、ISBN、题名、作者、出版社、复本数、语种、文献类型、版次等字段;③馆藏表:馆藏号、索书号、分类号、种次号、馆藏位置、单价、出版日期等字段;④流通表:借书证号、馆藏号、借期、还期、续借、应还期、操作员等字段;⑤借阅规则表:读者类别编码、图书类别编码、限借册数、每期天数、续借天数、过期日期、罚金等字段;⑥读者类别表:读者类别编码、读者类别等字段;⑦图书类别表:图书类别编码、图书类别等字段。??

3数据库索引??

建立索引是加快查询速度的有效手段,数据库的每一个表建立了主键,主键由一个或几个字段组成,每一个表都按主键建立了索引,部分表为了满足查询和排序的需要,除建立主索引外,还建立了次索引。例如在查询时要用到“馆藏号”、“作者”、“题名”等条件来查找图书,因此,在书目表上除了对主键“馆藏号”建立了主索引外,也对“作者”、“书名”等建立了次索引。??

4视图??

视图是从一个或几个基本表导出的表,它是定义在基本表之上的,它是一个虚表,数据库中只存放视图的定义,而不存放视图对应的数据,数据仍然存放在原来的基本表中。通过定义视图,可以使用户眼中的数据库结构简单、清晰,并可以简化用户的数据查询操作。由于本系统数据表较多,表中的字段多,为了简化对表的操作,我们创建了图书_按书名查询、期刊_按刊名查询、期刊_按编辑部查询、借阅规则查询、待还书查询、超期记录查询等30余个视图。??

5存储过程??

存储过程是一段经过编译的程序代码,存放在数据库服务器端。通过调用适当的存储过程,可在服务器端处理大量数据,再将处理结果送到客户端。这样可减少数据在网络上的传送,消除网络阻塞现象;例如:要查询某条记录,若该记录在表中的顺序号是10000,不采用存储过程,服务器将从1至于10000条记录数据逐条送至客户端,采用存储过程后,由于过程是经过编译的并且是在本地,不需要通过网络,因此能很快查出所需记录并将结果送到客户端,大大减少了网上数据传输量。存储过程另一好处是可供不同的开发工具调用,如PB、VB、ASP、Delphi等开发工具均可调用。在流通模块和WEB查询模块上均有图书检索功能,实际上调用同一存储过程完成的。本系统建立了60多个存储过程,实现诸如借还书处理、新书入库统计、编目入馆藏、读者统计、生成索书号等功能。??

6数据库调用??

Client/Server采用ODBC接口实现数据库的调用,Browser/Server采用ADO接口调用。??

参考文献:??

[1]宫昌利.图书管理系统的设计与实现[D].山东大学,2009.??

[2]顾俐.图书馆图书管理系统的设计[J].中国科技信息, 2007(11).??

[3]赵晨.图书管理系统[D].吉林大学,2009.??

[4]陈杰志.图书管理系统[D].华南理工大学,2011.??

[5]黄剑樱.高校图书管理系统的设计与实现[D].电子科技大学,2007.??

[6]栾丁.图书管理系统设计与实现[D].吉林大学,2010.??

[7]花昀峤.基于面向对象技术的图书管理系统研究[D].吉林大学,2010.??

[8]张佳慧.图书信息管理系统的设计与实现[D].电子科技大学, 2009.

?ぃㄔ鹑伪嗉?:王钊)

第8篇:图书管理系统数据库的设计

摘 要:书籍是人类不可缺少的精神食粮,尤其对一些学校来说,尤其重要。所以图书馆借阅信息管理系统应该能够为用户提供充足的信息和快捷的查询手段。文章以开发一套图书馆借阅信息管理系统为例,谈谈图书管理系统数据库的设计。

关键词:信息抽取;图书查询;数据库设计

1 系统设计

系统开发的总体目的是在图书馆信息管理中实现管理的系统化、自动化,减少工作量,增加效率及可靠性。

图书管理系统的主要功能有:

(1)系统权限的管理。包括系统登录,密码修改,管理员添加等。

(2)图书类别的管理,即图书类别添加、修改、查询。包括图书类别的编号、名称等。

(3)入库图书的管理,即新进图书的登记,馆藏图书的修改、删除、查询和报损。包括图书的编号、索书号、中文名、原名、原作、译者、图书类别、语种、出版社等。

(4)期刊类别的管理,即期刊类别的添加、修改、查询。包括期刊种类的编号、名称、允许借阅的天数等。

(5)入库期刊的管理,即新进期刊的登记,馆藏期刊的修改,删除,查询和报损。包括期刊的编号、期刊名、统一刊号、期刊类别、期刊等级、语种、期号、总期号、出版日期、编辑部等。

(6)读者信息的管理,即读者信息的添加、修改、删除、查询。包括借书者的编号、类型、性别、身份证号、工作单位、办证日期等。

(7)借书信息的管理,即信息的添加、修改、删除、查询。包括借书者编号、姓名、类别,所借书编号、名称、原名、作者、书籍类别、出版社、借出日期、应还日期等。

(8)还书信息的管理,即信息的添加、修改、删除、查询。包括还书者编号、姓名、类别,所还书编号、名称、原名、作者、书籍类别、出版社、借出日期、应还日期、实还日期等。

(9)每日盘点,即每日进书、每日借书、每日还书。

对上述功能进行分析和集中,按照模块化程序设计的要求,得到如图1所示的系统功能模块图。

数据库是信息管理系统的后台,存储着所有的信息,在信息管理系统中占有非常重要的地位。数据库结构设计的好坏对应用系统的效率及实现产生直接影响,而且也将有利于程序的实现。

2 数据库设计

2.1 数据库的分析

用户的需求具体体现在各种信息的提供、保存、修改、查询等方面,经调查和分析,针对一般图书馆管理信息系统的需求和对系统流程图的分析,设计如下所示的数据项和数据结构(见图1)。

(1)图书类别信息,包括类别编号、类别名、允许借出天数和备注信息。

(2)图书信息,包括图书编号、索书号、图书名称、原文名称、作者、译者、出版社、图书类别、出版日期、图书语种、图书页码、图书价格、等级日期和图书备注。

(3)图书报损信息,包括报损日期、图书编号、图书名、图书价格、读者编号、读者姓名、报损金额和备注信息。

(4)期刊类别信息,包括期刊类别编号、类别名、借出天数和备注信息。

(5)期刊信息,包括期刊的编号、期刊名、统一刊号、期刊类别、期刊等级、语种、期号、总期号、出版日期、编辑部等。

(6)期刊报损信息,包括报损日、期刊编号、期刊名、期号、总期号、、图书原价、包损金额、读者编号、读者姓名和期刊备注信息。

(7)读者信息,包括读者编号、读者姓名、读者性别、读者类别、身份证号、工作单位、EMAIL。

(8)联系电话、办证日期、有效日期和备注。

(9)借书信息,包括读者编号、读者姓名、读者类别、书籍编号、书籍名称、书籍原名、书籍类别、书籍作者、出版社、借书日期、应还日期和借书备注。

(10)还书信息,包括读者编号、读者姓名、读者类别、书籍编号、书籍名称、书籍原名、书籍类别、书籍作者、出版社、借书日期、应还日期、实还日期、罚款金额和借书备注。 2.2 数据库逻辑结构设计

启动A c c e s s,创建一个新的数据库,命名为“liararyMIS.mdb”,保存在存放这个系统的所在工程文件的文件夹中。

数据库“liararyMIS”包含以下10个表:“系统用户信息表user_Info”“读者信息表readers”“图书类型表booktype”“图书信息表books”“期刊类型表magezineType”“期刊信息表magazines”“借书信息表borrowtnfo”“还书信息表returnInfo”“报损图书表rejectbooks”“报损期刊表rejectmgzs”。

(1)系统用户信息表user_Info用来保存系统用户的信息,包括用户名和密码。

(2)读者信息表readers用来保存读者的基本信息。

(3)图书类型表booktype用来保存图书的类型信息。

(4)图书信息表books用来保存图书的基本信息。

(5)期刊类型表magezineType用来保存期刊的类型信息。

(6)期刊信息表magazines用来保存期刊的基本信息。

(7)借书信息表borrowtnfo用来保存图书的借阅信息。

(8)还书信息表returnInfo用来保存图书的还书信息。

(9)报损图书表rejectbooks用来保存报损图书的信息。

(10)报损期刊表rejectmgzs用来保存报损期刊的信息。

[参考文献]

[1]周国民.Visual Basic+Access 数据库项目开发实践[M].北京:中国铁道出版社,2005.

[2]邝孔武,王晓敏.信息系统分析与设计[M].北京:清华大学出版社,1999.

Design of Library Management System Database

Dai Xiaofeng

(Nantong Polytechnic College,Nantong 226002, China)

Abstract:Book is an indispensable spiritual nourishment, especially for some schools is particularly important. This paper takes the development of a set of library management information system as an example, to discuss the design of library management system database.

Key words:information extraction; book query; database design

第9篇:图书馆管理系统详细设计报告

1 引言

1.1 编写目的

本文档为C3图书管理系统的详细设计说明书,向阅读人 员介绍本图书管理系统的整体框架和详细设计。 1.2 背景 系统描述

BMS系统为图书馆书籍管理,企业图书、材料管理提供了一个方 便的电子平台。该系统分为图书管理模块,图书信息查询、预览 模块,图书评价模块,读者信息管理模块,书籍借阅和归还管理

模块以及管理员模块等模块。图书管理系统软件是一套功能比较

完善的图书数据管理软件,具有数据操作方便高效迅速等优点。 使用。除此以外,BMS可通过访问权限控制以及数据备份功能,确保数据的安全性。 1.3 定义 术语:

BMS BookManagementSystem 图书管理系统 1.4 参考资料

《数据库系统概念》 Abraham Silberschatz Henry F.korth 《软件工程导论——第4版》 张海藩 清华大学出版社 2 程序系统的组织结构 2.1系统架构

本系统包含客户层,中间层和图书管理信息系统层。其中,客户层用于用户与客户端的交互,例如显示信息,查询信息,提交信息,输入数据等。中间层为应用服务器部分,主要用来实现数据的接收,发送,并作为一座“桥梁”来连接客户与数据库。图书管理信息系统层主要实现数据的处理功能。

从安全的角度看,中间层的引入能有效的对系统与数据进行保护,用户无法直接修改,删除核心信息,从而使系统安全性得到保障,有效地避免数据丢失等问题的出现

管理员在得到读者归还图书的需求时,在在图书借阅记录表中查询到该借阅信息。根据该信息判断图书是否是该处借出图书,判断图书是否逾期,是否需要对读者罚款。并修改图书借阅记录表和读者借阅记录。

3 程序1(注册登录模块)设计说明 3.1 程序描述

读者第一次使用该系统,需要通过注册才能成为系统的用户。登录系统后,用户可以使用系统开放给普通用户的各种功能。在个人信息中,注册用户还可以查看并修改自己的个人信息。丢失自己密码的注册用户可以通过个人资料认证来重新找回自己的密码。 3.2 功能

注册部分:非会员输入注册信息,系统判断注册信息的正确性,如果正确,在数据库插入新的读者信息,并返回欢迎信息。 取回密码部分:读者输入读者ID,系统取出该读者ID的密码和注册邮箱,将密码发送到该邮箱中。 登录部分:管理员输入登录名和密码,系统判断密码正确性,如果正确,向管理员提供管理员相关功能。读者输入登录名和密码,系统判断密码正确性,如果正确,向其提供读者相关功能. 3.3 性能

–允许读者测试注册读者ID的合法性 –提供足够的帮助信息,诱导用户输入

–允许读者跳过某些非关键信息,允许读者更改输入次序 3.4 输入项

–注册部分:输入注册信息,包括用户名,姓名,地址,Email, 电话号码,密码等。 –取回密码部分:输入用户名以及Email,电话号码中至少一项 –登录部分:读者输入用户名与密码,管理员输入管理员ID与密 码。 3.5 输入项

–注册部分:如果成功,输出欢迎信息;否则出现失败提示信息。 –取回密码部分:如果成功,显示成功信息,并将密码发送至Email 中;失败则显示失败提示信息。

–登录部分:如果成功,输出欢迎信息;反之则提示失败信息。 3.6 算法

–注册部分:首先判断数据库中的读者ID是否存在,如果存在, 提示错误信息,如果不存在再判断输入数据是否符合输入要求, 不符合要求,提示具体错误信息,反之则将注册读者信息存入到 数据库中。

–取回密码部分:首先判断输入的读者ID是否存在,不存在则提 示错误信息,存在则将该读者的密码发送至会员提供的Email中。 –登录部分:首先判断读者ID是否存在如果输入的读者名不存 在,提示错误信息,然后检查密码与读者ID是否对应,不对应则 提示错误信息,对应输出欢迎信息。

3.7 流程逻辑

3.8 接口 数据库接口 3.9 存储分配

读者信息存储在数据库tb_reader表中,管理员信息存储在数据库 tb_admin中. 3.10 注释设计

用/*„„*/作多行注释,用//作单行注释 3.11 限制条件

取回密码时读者的邮箱地址一定要合法的,才能把密码发送到该 邮箱中。 3.12 测试计划

用多组重复的读者ID测试错误信息的检查与显示,用不符合要求 的读者信息注册测试系统错误处理能力。

注:本文为网友上传,旨在传播知识,不代表本站观点,与本站立场无关。若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:iwenmi@163.com。举报文章