




免费预览已结束,剩余14页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
图书馆数据库实验报告一、 数据库总体说明1、 表设计(sqlsever2000截图)表一:书表二:借书证表三:借书记录表四:管理员2、 表约束(sqlsever2000截图)2.1 外键二、e-r模型年份书号借书卡号借书卡号借书卡号借书卡号借书卡号操作维护类别管理员类别卡号姓名单位经手人借期借书证还期借书卡号借书书号借书记录作者价格库存总藏书量书名出版社书三、系统架构系统登陆界面1发系统主界面2图书管理系统界面3借书证管理系统界面4借还书系统界面5图书入库界面7图书查询界面6数据库(sqlsever2000)其中系统登录界面需连接数据库,与表“管理员”中的“管理员”及“密码”核对,正确才能进入系统主界面。图书入库界面、图书查询界面、增添借书证界面及借还书系统界面都需连接数据库。数据库连接通过delphi7中的sqlquery及dataconnection功能实现。本程序共8个界面,每个界面有一定的功能。界面1是登陆界面,用户输入id和密码,若于数据库里的相关数据一致则可进入系统主界面;界面2是主界面,通过它可以进入图书管理系统界面、借书证管理系统界面和借还书系统界面;界面3是图书管理系统界面,通过它可以进入界面7即图书入库界面从而进行图书入库操作,也可进入界面6即图书查询界面进行图书查询操作;界面4是借书证管理系统界面,可进行借书证的删除与增加操作;界面5是借还书系统界面,可进行借还书操作。四、采用技术说明1、所选开发环境dlphi简介这次试验,我们选用了delphi作为开发工具。delphi是全新的可视化编程环境,为我们提供了一种方便、快捷的windows应用程序开发工具。它使用了microsoft windows图形用户界面的许多先进特性和设计思想,采用了弹性可重复利用的完整的面向对象程序语言(object-oriented language)、当今世界上最快的编辑器、最为领先的数据库技术。对于广大的程序开发人员来讲,使用delphi开发应用软件,无疑会大大地提高编程效率,而且随着应用的深入,您将会发现编程不再是枯燥无味的工作delphi的每一个设计细节,都将带给您一份欣喜。delphi实际上是pascal语言的一种版本,但它与传统的pascal语言有天壤之别。一个delphi程序首先是应用程序框架,而这一框架正是应用程序的“骨架”。在骨架上即使没有附着任何东西,仍可以严格地按照设计运行。您的工作只是在“骨架”中加入您的程序。缺省的应用程序是一个空白的窗体(form),您可以运行它,结果得到一个空白的窗口。这个窗口具有windows窗口的全部性质:可以被放大缩小、移动、最大最小化等,但您却没有编写一行程序。因此,可以说应用程序框架通过提供所有应用程序共有的东西,为用户应用程序的开发打下了良好的基础。delphi已经为您做好了一切基础工作程序框架就是一个已经完成的可运行应用程序,只是不处理任何事情。您所需要做的,只是在程序中加入完成您所需功能的代码而已。在空白窗口的背后,应用程序的框架正在等待用户的输入。由于您并未告诉它接收到用户输入后作何反应,窗口除了响应windows的基本操作(移动、缩放等)外,它只是接受用户的输入,然后再忽略。delphi把windows编程的回调、句柄处理等繁复过程都放在一个不可见的romulam覆盖物下面,这样您可以不为它们所困扰,轻松从容地对可视部件进行编程。12、 pascal语言简介delphi的编程语言是以pascal为基础的。pascal语言具有可读性好、编写容易的特点,这使得它很适合作为基础的开发语言。同时,使用编译器创建的应用程序只生成单个可执行文件(.exe),正是这种结合,使得pascal成为delphi这种先进开发环境的编程语言。在编写自己的object pascal程序时,要注意程序的可读性。pascal语言是英式结构语言,在程序中选择合适的缩排、大小写风格,并在需要时将程序代码分行,会使得程序代码能够很容易地被自己和他人读懂。一般的程序员都有这样的体验:如果不给程序加上适当的注解,一段时间后,自己也难以理清程序的流程。给程序及时地加上注释是良好的编程习惯。delphi的注释需要加注在之间,编辑器会把它们处理成为空白。delphi保留了borland pascal编辑器的风格,关键字采用黑体字,被注释的部分会变暗,这使得编程风格良好,易读易写。在事件处理过程中,最常用到的工作就是把一个新值赋给一个属性或变量。在设计用户界面时,可以使用object inspector(object inspector)来改变其属性;但有时需要在程序执行时改变属性的值,而且有些属性只能在执行时改变,这些属性在delphi的在线帮助的“proprety”主题中被标为执行期属性。过程与函数是程序中执行特定工作的模块化部分。delphi的运行库包含许多过程与函数以供您的应用程序调用。您不必了解过程与函数的逻辑,但要知道过程与函数的用途。在对象中说明的过程和函数称为方法(method)。所有的事件处理过程都是过程,以保留字procedure开头。每一个事件处理过程只包含了当这一事件发生时需要执行的程序代码。在事件处理过程中使用delphi已经存在的过程与函数,只需在程序代码中调用它们即可。23、 delphi7中所用组件说明以下只介绍,我们所使用的delphi组件,以及我在程序设计中的应用。(1).standard栏的lable组件,edit组件,memo组件,button组件,panle组件。分别简单介绍:label部件 label(标签)一般放在对象的旁边,用来标记这些对象,从而对用户的操作进行提示,也可以用来显示其它信息。您可以在标签中设置热键,也即在caption属性值段中输入含有“&”的字串,当用户使用“alt+关键字母”时,将自动选中它所指向的对象。edit部件 部件都是用作接收、显示用户输入文本的。readonly在运行时间内控制对象是否可以进行windows的操作,当此值为false时,该框内的文本就不能被复制到剪贴板上。maxlength可以设置输入文本的长度限制。用passwordchar属性可以按照显示隐蔽密码的方法显示用户输入文本memo部件memo是备注框,与以上对象不同的是,它可以接收多行文本输入。将scrollbars设置成ssvertical,可以为它加上一个垂直的滚行条。align属性调整该对象在窗口中的对齐情况,有alnone(无对齐指定)、albottom(底部对齐)、alclient(全窗口显示)等可以选择;而alignment属性则决定了文本在框中的对齐显示格式。button部件按钮是windows常用的部件,前文的例程中我们已经基本掌握了button和bitbtn的主要用法。它们一般用在对话框中,做为执行某种功能的指示。您也可以为它们设置内置返回功能,将modelresult属性加以匹配,可以不用编程,直接实现系统内置的功能,这一点上和kind属性颇类似。panle部件panle有标题,可以用文字表征成组部件的标题或信息。panel部件也可以达到将部件分组的目的。通过编程向窗口加一个操作板部件,以书写提示和帮助信息,也不失为一种好方法。(2). additional栏的bitbtn部件,image部件。bitbtn部件与button基本相同,不过可以在旁边加入图案,使按钮功能更鲜明。image部件 图象部件image在additional页上,用来在窗口中显示一幅图片,可以在picture属性中调入图象文件。delphi支持位图(.bmp)、图标(.ico)、图元(.wfm)三种文件格式。比较重要的属性是autosize和strech。它们决定了图象在窗口中的显示尺寸。autosize属性为true表示按原尺寸显示,strech属性为true表示图象按对象图框的大小显示,这时图象的大小可以人为改变。(3). system中的timer部件。计时器部件timer在system页上,还有一个(timer计时器)部件,它能够有规律地触发ontimer事件,发送信息给应用程序。它是编制应用程序时最为重要的部件之一。enabled属性表示了计时器打开还是关闭;用interval属性设置两个ontimer事件间的间隔,单位是毫秒,也即千分之一秒。将间隔置为0相当于关闭计时器,interval的最大允许值是32767,也即32.767秒。(4). data access栏中的datasource部件datasource部件,顾名思义是用来访问数据源的部件。(5). ado栏中的adoconnection部件,adoquery部件。adoconnection部件负责部相应的数据库进行连接的部件。它是存取磁盘上数据库表的媒介,它通过ado存取数据库表中的数据,再与tdatasource 进行“对话”,使得数据浏览部件能够有效地从部件中访问数据并能显示和编辑其中的数据。adoquery部件 tquery 并与tdatasource“对话”,实现数据浏览部件对数据库的访问。(6). datacontrol栏里的dbgrid部件dbgrid用来显示查询数据库得到的内容。五、各模块说明1、系统登录界面双击exe文件会进入此界面:单击“进入登陆界面”会进入登陆界面:管理员输入登陆id和密码后,点击“登陆”按钮,如果验证通过(与数据库表“管理员”里的信息一致),则进入主界面;如果没通过,则关闭。非管理员只能通过右边登陆按钮登陆,登陆后直接到图书查询界面,该界面只能返回到登陆界面。即非管理员只能进行查询操作。附:登录按钮程序:procedure tform1.button1click(sender: tobject);var id :string; code :string;beginwith adoquery1 do begin id:=edit1.text; code:=edit2.text; sql.clear; sql.add(select * from 管理员 where 管理员id=:a and 密码=:b); parameters.parambyname(a).value:=id; parameters.parambyname(b).value:=code; open; if not adoquery1.eof then form2.show; form1.close;end;end;退出按钮程序:procedure tform1.button2click(sender: tobject);beginclose;end;登陆按钮(右边)程序:procedure tform1.button3click(sender: tobject);beginform6.show;form1.close;end;2、系统主界面 单击“图书管理系统”,进入图书查询与入库界面;单击“借书证管理系统”进入借书证管理界面;单击“借还书管理界面”进入借还书界面。附:图书管理系统按钮程序:procedure tform2.button1click(sender: tobject);beginform3.show;form2.hide;end;借书证管理系统按钮程序:procedure tform2.button2click(sender: tobject);beginform4.show;form2.close;end;借还书管理系统按钮程序:procedure tform2.button3click(sender: tobject);beginform5.show;form2.close;end;退出按钮程序:procedure tform2.button5click(sender: tobject);beginclose;end;3、图书查询与入库界面单击“图书查询”,进入图书查询操作界面;单击“图书入库”进入图书入库操作界面。附:图书查询按钮程序:procedure tform3.button1click(sender: tobject);beginform6.show;form3.close;end;图书入库按钮程序:procedure tform3.button2click(sender: tobject);beginform7.show;form3.close;end;end.返回主界面按钮程序:procedure tform3.button3click(sender: tobject);beginform2.show;form3.close;end;4、 借书证管理界面输入借书证卡号,单击“删除借书证”,如果输入的卡号在数据库里有记录,那么表“借书证”里的这个借书证将被删除。输入卡号、姓名、单位、类别后,如果卡号在表“借书证”里不存在,那么将被添加;类别只能填“学生”或“教工”。附:删除借书证按钮程序:procedure tform4.button1click(sender: tobject);begin if edit1.text= then begin application.messagebox(请填写读者证号!,提示,mb_iconerror); exit; end;try with adoquery1 do begin sql.clear; sql.add(select * from 借书证 where 卡号=:卡号); parameters.parambyname(卡号).value := trim(edit1.text); open; if recordcount=0 then begin messagedlg(读者卡号不存在!,mterror,mbok,0); edit1.text:=; exit; end; if recordcount0 then begin sql.clear; sql.add(delete from 借书证 where 卡号=:卡号); parameters.parambyname(卡号).value := trim(edit1.text); execsql; application.messagebox(借书证删除成功!,提示,mb_iconinformation); end; end; finally end; end;办理按钮程序:procedure tform4.button5click(sender: tobject);begin if (trim(edit5.text)=) or (edit2.text=) or (edit3.text=) or (edit4.text=)then begin application.messagebox(请填写完整!,提示,mb_iconerror); exit; end; with adoquery1 do begin adoquery1.close; adoquery1.sql.clear; adoquery1.sql.add(insert into 借书证(卡号,姓名,单位,类别); adoquery1.sql.add(values(+trim(edit5.text)+,+edit2.text+,+edit3.text+,+edit4.text+); adoquery1.execsql; showmessage(注册成功); edit5.text:=; edit2.text:=; edit3.text:=; edit4.text:=; end;end;返回主界面按钮程序:procedure tform4.button6click(sender: tobject);beginform2.show;form4.close;end;5、 借还书界面同学借还书,首先输入借书证卡号,显示其已借书信息。然后再输入书号和id可借书,如果书号在表“书”里存在,卡号在表“借书证”里存在,id在表“管理员”里存在,且书号对应的库存大于0,那么借书成功,该书的库存将被减去1,借书记录里会记录下借书记录(借书书号、卡号、借期、还期、经手人);再输入书号可还书,该书库存将被加1,同时相应的借书记录将被删除。附:确定按钮:procedure tform5.button4click(sender: tobject);beginwith adoquery1 do begin sql.clear;sql.add(select * from 借书记录 where 借书卡号= +edit2.text+ ); adoquery1.open; end;end;借书按钮程序:procedure tform5.button1click(sender: tobject);vari:integer; begin with adoquery1 do begin sql.clear; sql.add(select * from 书 where 书号=:书号); parameters.parambyname(书号).value:=trim(edit1.text); open; i:=fieldbyname(库存).asinteger; if i= 0 then begin application.messagebox(对不起,该书已全部借出,提示,mb_iconinformation); end; if i0 then with adoquery1 do begin sql.clear; sql.add(update 书 set 库存=:库存 where 书号=:书号); parameters.parambyname(书号).value:=trim(edit1.text); parameters.parambyname(库存).value:=i-1; adoquery1.execsql; end; with adoquery1 do begin sql.clear; sql.add(insert into 借书记录(借书卡号,借书书号,借期,还期,经手人) values (+edit2.text+,+edit1.text+,20110106,20110215,+edit4.text+); execsql; showmessage(借书成功!) end; end; end;还书按钮程序:procedure tform5.button2click(sender: tobject);begin adoquery1.sql.clear; if (edit3.text= ) then showmessage(您要还什么书哦!) else beginadoquery1.sql.add( delete from 借书记录 where 借书书号=+edit3.text+ and 借书卡号=+edit5.text+);adoquery1.sql.add( update 书 set 库存=库存+1 where 书号=+edit3.text+);adoquery1.execsql; showmessage(还书成功!);end; end;返回主界面程序:procedure tform5.button3click(sender: tobject);beginform2.show;form5.close;end;6、 书查询进行书查询,先选择查询项,再输入内容,可以选择模糊查询。查询后右边的框里将显示结果,框下面会显示查询到的数量。附:查询按钮程序:procedure tform6.button1click(sender: tobject);varquery_str : string;begintryquery_str :=trim(edit4.text);if checkbox1.checked then query_str := %+query_str +%;with adoquerybookquery do begin sql.clear; if radiobutton1.checked then begin sql.add(select * from 书 where 书号 like :书号); parameters.parambyname(书号).value := query_str; end; if radiobutton2.checked then begin sql.add(select * from 书 where 书名 like :书名); parameters.parambyname(书名).value := query_str; end; if radiobutton3.checked then begin sql.add(select * from 书 where 出版社 like :出版社); parameters.parambyname(出版社).value := query_str; end; if radiobutton4.checked then begin sql.add(select * from 书 where 作者 like :作者); parameters.parambyname(作者).value := query_str; end; adoquerybookquery.open; label2.caption := 共查到+inttostr(recordcount)+条记录; / application.messagebox(查询成功!,提示,mb_iconinformation); end; except messagedlg(查询失败,mterror,mbok,0); end; end;返回主界面按钮程序:procedure tform6.button2click(sender: tobject);beginform2.show;form6.close;end;7、 图书入库分为新书入库,和已有数目入库。在左边输入书号等信息,如果书号在表“书“里已存在,那么将会被提醒到界面右边办理;反之也一样。目的在于,对于已存在的数目进行入库操作,只需输入书号即可,减少工作人员的工作量。新书入库后,藏书量和库存量都为1。对于已存在数目入库,库存和藏书量都将被加1。附:入库(左边)按钮程序:procedure tform7.button1click(sender: tobject);beginwith adoquery1 do /检查卡号是否存在 begin sql.clear; sql.add(select * from 书 where 书号=:书号); parameters.parambyname(书号).value := edit1.text; open; if recordcount 0 then begin messagedlg(该书号已经存在,请到已有书目入库进行入库操作!,mterror,mbok,0); edit1.setfocus; exit; end; close; end; with adoquery1 do begin sql.clear; sql.add(insert into 书(书号,类别,书名,出版社,年份,作者,价格,总藏书量,库存)+ values(:书号,:类别,:书名,:出版社,:年份,:作者,:价格,:总藏书量,:库存); parameters.parambyname(书号).value:=trim(edit1.text); parameters.parambyname(类别).value:=trim(edit2.text); parameters.parambyname(书名).value:=trim(edit3.text); parameters.parambyname(出版社).value:=trim(edit4.text); parameters.parambyname(年份).value:=trim(edit5.text); parameters.parambyname(作者).value:=trim(edit6.text); parameters.parambyname(价格).value:=trim(edit7.text); parameters.parambyname(总藏书量).value:=1; parameters.parambyname(库存).value:=1; execsql; application.messagebox(图书入库成功!,提示,mb_iconinformation); end; end; 入库(右边)按钮程序: p
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025-2026学年宁夏固原市彭阳县数学三上期末预测试题含解析
- 2025-2026学年嘉峪关市三年级数学第一学期期末监测试题含解析
- 2025-2026学年崇左市大新县数学三上期末达标检测试题含解析
- 2024年咸阳市永寿县数学三上期末统考模拟试题含解析
- 2024年宁夏回族吴忠市利通区数学三年级第一学期期末复习检测试题含解析
- 2024年江苏省徐州市邳州市数学三上期末调研试题含解析
- 七年级思想品德丰富多样的情绪课件
- 执业药师对药物滥用的干预知识试题及答案
- 2025年行政管理语文考试易混淆试题及答案
- 2025年主管护师考试成功之路试题及答案
- 清华大学课程结构与教学模式
- 【MOOC】航空航天材料概论-南京航空航天大学 中国大学慕课MOOC答案
- 新能源材料与器件基础知识单选题100道及答案解析
- 市容环境卫生业务培训
- 工程咨询费用支付协议
- 《化学药剂公司营运资金管理问题和对策:以云南白药公司为例(8800字论文)》
- 2024江苏省中等职业学校学业水平考试思想政治卷及答案
- 国家职业技术技能标准 4-03-02-10 调饮师 人社厅发202338号
- Unit 1 Travel教案-2023-2024学年高一下学期 中职英语高教版(2023修订版)基础模块2
- ASTM-D3359-(附著力测试标准)-中文版
- 统编版五年级下册语文第七单元情景化检测题(含答案)
评论
0/150
提交评论