WEB课程设计图书借阅信息管理系统(共24页)

上传人:风*** 文档编号:57010396 上传时间:2022-02-23 格式:DOC 页数:24 大小:454KB
收藏 版权申诉 举报 下载
WEB课程设计图书借阅信息管理系统(共24页)_第1页
第1页 / 共24页
WEB课程设计图书借阅信息管理系统(共24页)_第2页
第2页 / 共24页
WEB课程设计图书借阅信息管理系统(共24页)_第3页
第3页 / 共24页
资源描述:

《WEB课程设计图书借阅信息管理系统(共24页)》由会员分享,可在线阅读,更多相关《WEB课程设计图书借阅信息管理系统(共24页)(24页珍藏版)》请在装配图网上搜索。

1、精选优质文档-倾情为你奉上1绪论1.1数据库应用系统简介SQL Server 2005数据库是微软公司精心打造的企业级数据库平台产品,该产品不仅包含了丰富的企业及数据管理功能,还集成了商业智能等特性。数据库由DBMS(数据库管理系统)处理,DBMS则由开发人员和用户通过应用程序直接或间接地使用。它主要包括四个要素:用户数据、元数据、索引和应用元数据。1.2 Visual Studio 2008 开发平台Visual Studio 是一套完整的开发工具集,用于生成 ASP.NET Web 、XML Web Services、和移动应用程序。、Visual C+、Visual C# 和 Visua

2、l J# 全都使用相同的 (IDE),利用此 IDE 可以共享工具且有助于创建混合语言解决方案。另外,这些语言利用了 .NET Framework 的功能,通过此框架可使用简化 ASP Web 应用程序和 XML Web Services 开发的关键技术。1.3图书管理系统当今时代是飞速发展的信息时代。在各行各业中离不开信息处理,这正是计算机被广泛应用于信息管理系统的环境。计算机的最大好处在于利用它能够进行信息管理。使用计算机进行信息控制,不仅提高了工作效率,而且大大的提高了其安全性。图书馆作为一种信息资源的集散地,图书和用户借阅资料繁多,包含很多的信息数据的管理,现今,有很多的图书馆都是初步

3、开始使用,甚至尚未使用计算机进行信息管理。根据调查得知,他们以前对信息管理的主要方式是基于文本、表格等纸介质的手工处理,对于图书借阅情况(如借书天数、超过限定借书时间的天数)的统计和核实等往往采用对借书卡的人工检查进行,对借阅者的借阅权限、以及借阅天数等用人工计算、手抄进行。数据信息处理工作量大,容易出错;由于数据繁多,容易丢失,且不易查找。总的来说,缺乏系统,规范的信息管理手段。尽管有的图书馆有计算机,但是尚未用于信息管理,没有发挥它的效力,资源闲置比较突出,这就是管理信息系统的开发的基本环境。数据处理手工操作,工作量大,出错率高,出错后不易更改。图书馆采取手工方式对图书借阅情况进行人工管理

4、,由于信息比较多,图书借阅信息的管理工作混乱而又复杂;一般借阅情况是记录在借书证上,图书的数目和内容记录在文件中,图书馆的工作人员和管理员也只是当时对它比较清楚,时间一长,如再要进行查询,就得在众多的资料中翻阅、查找了,造成查询费时、费力。如要对很长时间以前的图书进行更改就更加困难了。基于这此问题,我认为有必要建立一个图书管理系统,使图书管理工作规范化,系统化,程序化,避免图书管理的随意性,提高信息处理的速度和准确性,能够及时、准确、有效的查询和修改图书情况。2数据库设计2.1 数据库分析本系统利用Visual Studio 2008处理数据库的功能,实现对图书馆信息的管理。主要功能为管理有关

5、用户、管理员、书籍和借阅的信息等。本系统的结构分为用户信息管理模块、书籍信息管理模块、借阅信息管理模块、管理者管理信息模块和查询处理模块。图书馆管理系统框图如图2-1所示成功进入图书馆管理系统管理员用户查询图书借阅图书图书管理查询图书增加图书修改图书删除图书登录失败 图2-1 图书馆管理系统框图2.2 E-R模型设计2.2.1 实体列表实 体描 述用 户所有借阅者,查阅者,以及系统管理员,由用户ID标识图 书图书馆所有图书,由图书ID标识借 阅图书ID、借阅ID、借书日期、借阅证号等属性,由借阅ID标识2.2.2系统的E-R模型该图书管理系统的E-R模型,如图2-2所示用户图书借阅图书管理管理

6、员UIDUNameUPwdUBookIDUStateBookIDBookNameBookTypeBookAuthorBookPriceBookPicBookContentBookIssueIssIDBookIDIssBookIDIssDateTimemN1m2-2 系统的E-R模型2.3 设计数据库2.3.1创建数据库(1)在服务器资源管理器中的任一节点右击。 (2)执行快捷菜单中的“新建数据库”命令,并在打开的“创建数据库”对话框中输入数据库名BookManage,其他可采用默认值。 (3)单击“确定”按钮,则新建的数据库就会出现在服务器上。2.3.2创建数据表创建数据库后,为BookMan

7、age数据库添加数据表,步骤如下。 (1)在服务器资源管理器中右击数据库BookManage下的“表”文件夹在弹出的快捷菜单中执行“新建表”命令。 (2)添加表的字段和其他详细资料。各表数据结构如下表所示。 表2-1 用户信息(userinfo)列 名含 义数据类型说明UID用户IDint自动,主键UName用户名vchar(50)不为空UPwd密码vchar(50)不为空UState用户权限,管理员=1,普通用户=2int不为空,默认值为2UBookID借阅证号bigint可以为空 表2-2 图书信息(bookinfo)列 名含 义数据类型主 键BookID图书IDbigint自动,主键Bo

8、okName图书名称Varchar(50)不为空BookType类别Varchar(100)不为空BookAuthor作者Varchar(100)不为空BookPrice价格smallmoney不为空BookPic封面Varchar(200)允许为空BookContent内容简介text不为空BookIssue图书制定访问码Varchar(50)不为空 表2-3 借阅信息(issueinfo)列 名含 义数据类型说明IssID借阅IDbigint自动,主键BookID图书IDbigint外键IssBookID借阅证号bigint不为空IssDateTime借书日期datetime不为空2.4

9、数据库中表的关系在数据库中新建BookManage数据库的数据库关系图如图2-4所示图 2-4 数据库关系图3界面设计3.1 主界面进入Visual Studio 2008,创建一个新的“Windows应用程序”类型的项目,名为“图书馆管理”。将默认创建的窗体命名为“图书馆管理系统”,把“图书馆管理系统”作为本系统中的主界面。在窗体中添加一个菜单(MenuStrip)控件,一个工具栏(ToolStrip)控件。MenuStrip中的菜单项,子菜单项如图3-1所示图3-1 主界面3.2 用户登录界面本系统的用户非为普通用户和管理用户,管理用户具有系统提供的所有权限,普通用户可以查询图书、借阅图书

10、。在窗体中添加3个标签(Label)控件,2个按钮(Button)控件,1个组合框(ComboBox)控件,2个文本框(TextBox)控件。用户类型分为管理用户和普通用户,在组合窗口中添加这两项。3.3 图书查询界面图书查询提供组合查询的方式,界面窗体名称为“frmSearchBook.cs”,图书类别组合框中的项是从数据库中获取的,在设计时不需要添加内容。在条件组合框中输入“or”和“and”,来动态实现条件组合。在窗体中添加2个分组框(GroupBox)控件:搜索条件、搜索结果,各种控件的添加如图3-3所示图3-3 图书查询界面在右边的分组框中添加DataGridView控件,单击右上角

11、的黑色三角,选择“在父容器中停靠”选项。3.4 图书入库界面管理员有权限将图书添加到数据库中,图书入库界面的设计如图3-4所示图3-4 图书入库界面在窗体的左边的分组框中添加标签和文本框,用来接收管理员输入的图书信息,以便保存到数据库中。在右边的分组框中添加DataGridView控件,可以显示数据库中的图书信息,新添加的图书信息也可以显示出来。3.5 图书更新界面图书更新界面用于方便管理员管理图书信息,实现图书信息修改、删除等操作。界面设计如图3-5所示图 3-5 图书更新界面管理员可以在DataGridView控件中直接修改数据,也可以通过右边的分组框实现图书信息的修改。3.6 图书借阅界

12、面根据图书馆中已有的图书信息,用户可以通过图书证号实现借阅。界面设计如图3-6所示图 3-6 图书借阅界面4通用类的生成本系统的主要操作都需要与数据库发生交互,为了提高代码的重用性和规范性,把与数据库交互的功能单独放在一个类中,在该类中实现数据库的增加、删除、修改、查询等通用功能。连接数据库;(1)定义数据库连接字符串,代码如下:Private static string ConnectString = Data Source= (local)sqlexpress;DataBase=BookManage.mdf;(2)创建Connection对象,代码如下:SqlConnection con

13、= new SqlConnection(ConnectString);(3)打开连接,代码如下:con.Open();(4)关闭连接,代码如下:con.Close();5连接数据库为数据库BookManage和本系统之间建立一个数据连接。(1)在服务器资源管理器中右击“数据连接”节点(VS 2008中操作)。在弹出的快捷菜单中执行“添加连接”命令,打开Data Link Properties对话框。切换到Provider选项卡,选中列表框中的Microsoft OLE DB Provider for SQL Server项。单击“下一步”切换到Connection选项卡。(2)在其中的第一个下

14、拉列表框中选择数据库所在服务器名称。输入登录服务器信息后选择数据库BookManage,然后单击测试按钮。如果测试成功,单击“确定”按钮。6系统测试6.1 运行主窗口运行程序后首先显示主窗体,如图6-1所示单击“登录”按钮,就会弹出登录窗体,管理用户具有系统提供的所有权限,普通用户可以查询图书、借阅图书。图 6-1 主窗口在登录对话框中输入用户姓名和密码,单击“确认”按钮,就会对用户身份进行认证,如果认证通过,那么就会弹出如图6.2所示的图书馆管理系统的界面:管理员和普通用户进入此窗体后,系统所提供的操作权限是不同的6.2 图书查询功能图书查询可以实现组合查询,将查询结果显示在DataGrid

15、View控件中。窗体载入时,对图书类别组合框中的项进行了初始化,通过查询语句“select distinct BookType from bookinfo”,调用DataAccess类中的GetDataSetBySql方法获取数据库Bookinfo表中的图书类别,使用distinct关键字去掉重复项。使用查询功能示例如图6-2所示图6-2 图书查询6.3 图书更新功能图书更新分为两种,第一种通过更改DataGridView控件中的数据直接更改,第二种可以通过修改各字段值进行更改。单击“保存修改”按钮,将DataGridView控件中修改的数据保存到数据库中。如图6-3所示图6-3 图书更新6.

16、4 图书入库功能管理员登录系统后,可以为数据库添加新的图书信息。如图6-4所示如图6-4 图书入库6.5 图书借阅功能用户登录系统后,可以借阅不同的书籍,通过选择组合框中的书名,该书的图书访问代码和作者将显示在文本框中。如图6-5所示图6-5 图书借阅7问题分析与解决方法7.1 定义连接数据库字符串的技巧(1) stringconString=provider=sqloledb.1;datasource=.;initialcatalog=capucivar;userid=sa;pwd=; (2)private static string ConnectString = server=(loca

17、l)sqlexpress;database=Book_Data;user=sa;pwd=1234(3)Private static string ConnectString = Data Source= (local)sqlexpress;DataBase=BookManage.mdf;7.2 图书更新中删除功能的约束性在图书馆管理员管理图示信息时,有时需要不断地增添新的图书和删除旧的图书信息,但是当有一本图书正在被借阅当中,则不能删除,针对这一问题,该系统应该提供有关对管理员显示提醒的功能.下面在删除功能代码中用C#语句提供相应的解法.DataSet ds = DataAccess.GetD

18、ataSetBySql(select * from IssueInfo where BookID=+Convert.ToInt32(this.txtbID.Text)+); if (ds.Tables0.Rows.Count 0) MessageBox.Show(此书有借阅,不能删除); return; 7.3 图书查询功能的友好交互性对于一个藏书量很大的图书馆,一本图书可能有好几种版本,即作者不同、出版社不同、价格不同;或者同一类型的书:如计算机类的书有很多本。这时不同的用户就需要查询自己所需的书,在查询时就需要同时根据多项图书的信息进行关联性的查找,所以在查询功能这一块要用相应的算法解决这

19、一问题,如下面的代码所示,已经实现了图书的关联性查找:private void btnSerch_Click(object sender, EventArgs e) string cbo1 = this.cboOR.Text; string cbo2 = this.cboAnd.Text; string booktype = cboType.Text; string bookname = this.txtName.Text; string bookcontent = this.txtContent.Text; string sql = select * from bookInfo where

20、BookType= + booktype + + cbo1 + BookName like % + bookname + % + cbo2 + BookContent like % + bookcontent + %; DataSet Myds = DataAccess.GetDataSetBySql(sql); DataTable table = Myds.Tables0; this.dgvSearchBook.DataSource = table; 图 7-1 关联查找如图7-1所示 若要查询“爱情 情感”类中的“明晓溪”著作的心之萌这本书 就要同时对图书类别和图书名称这两个信息进行关联查

21、找:在图书类别下的组合框中选中“and”,图书类别中输入 爱情 情感,图书名称中输入 心之萌。附录操作数据库中的数据实现代码using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Data;using System.Data.SqlClient;namespace BookManage class DataAccess private static string ConnectString = Data Source =A20SQLEXPRESS;AttachD

22、bFilename=F:BookManagedataBookManage.mdf;Integrated Security=False;public static DataTable GetDataSetByTableName(string table) using (SqlConnection con = new SqlConnection(ConnectString) string sql = select * from + table + ; try SqlDataAdapter adapter = new SqlDataAdapter(sql, con); DataSet ds = ne

23、w DataSet(); adapter.Fill(ds, table); return ds.Tables0; catch (SqlException ex) throw new Exception(ex.Message); ; public static DataSet GetDataSetBySql(string sql) using (SqlConnection con = new SqlConnection(ConnectString) SqlDataAdapter adapter = new SqlDataAdapter(sql,con); DataSet ds = new Dat

24、aSet(); try adapter.Fill(ds); return ds; catch (SqlException ex) throw new Exception(ex.Message) public static SqlDataReader GetDataReaderByID(int id) using (SqlConnection con = new SqlConnection(ConnectString) string sql = select * from bookinfo where bookid= + id; try SqlCommand comm = new SqlComm

25、and(sql, con); con.Open(); SqlDataReader reader = comm.ExecuteReader(); reader.Read() return reader; catch (SqlException ex) throw new Exception(ex.Message); public static bool UpdateDataTable(string sql) using (SqlConnection con = new SqlConnection(ConnectString) try con.Open(); SqlCommand comm = n

26、ew SqlCommand(sql, con);/ if (comm.ExecuteNonQuery() 0) return true; else return false; catch (SqlException ex) throw new Exception(ex.Message); public static void UpdateDataSet(DataSet ds,string sql) using (SqlConnection con = new SqlConnection(ConnectString) try SqlDataAdapter adapter = new SqlDat

27、aAdapter(sql, con); SqlCommandBuilder builder = new SqlCommandBuilder(adapter); adapter.Update(ds, table); catch (SqlException ex) throw new Exception(ex.Message);主窗口实现代码using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq

28、;using System.Text;using System.Windows.Forms;namespace BookManage public partial class FrmMain : Form public static DialogResult result; public FrmMain() InitializeComponent(); public bool checkchildfrm(string childfrmname) foreach (Form childFrm in this.MdiChildren) if (childFrm.Name = childfrmnam

29、e) if(childFrm.WindowState =FormWindowState.Minimized) childFrm.WindowState = FormWindowState.Normal; childFrm.Activate(); return true; return false;private void 用户登录ToolStripMenuItem_Click(object sender, EventArgs e) if (this.checkchildfrm(frmLogin) = true) return; frmLogin user = new frmLogin(); u

30、ser.ShowDialog(); if (result = DialogResult.OK) this.tsbtnAddBook.Enabled = true; this.mnuUpdateBook.Enabled = true; this.mnuAddBook.Enabled = true; private void tsbtnLogin_Click(object sender, EventArgs e) if (this.checkchildfrm(frmLogin) = true) return; frmLogin user = new frmLogin(); user.ShowDia

31、log(); if (result = DialogResult.OK) this.tsbtnAddBook.Enabled = true; this.mnuUpdateBook.Enabled = true; this.mnuAddBook.Enabled = true; private void tsbtnSearch_Click(object sender, EventArgs e) if (this.checkchildfrm(frmSearchBook) = true) return; frmSearchBook book = new frmSearchBook(); book.Md

32、iParent = this; book.Show();private void 图书检索ToolStripMenuItem_Click(object sender, EventArgs e) if (this.checkchildfrm(frmSearchBook) = true) return; frmSearchBook book = new frmSearchBook(); book.MdiParent = this; book.Show(); private void 图书入库ToolStripMenuItem1_Click(object sender, EventArgs e) i

33、f (this.checkchildfrm(frmAddBook) = true) return; frmAddBook objbook = new frmAddBook(); objbook.MdiParent= this; objbook.Show(); private void tsbtnAddBook_Click(object sender, EventArgs e) if (this.checkchildfrm(frmUpdateBook) = true) return; frmUpdateBook objbook = new frmUpdateBook(); objbook.Mdi

34、Parent = this; objbook.Show(); private void 图书修改ToolStripMenuItem_Click(object sender, EventArgs e) if (this.checkchildfrm(frmUpdateBook) = true) return; frmUpdateBook objbook = new frmUpdateBook(); objbook.MdiParent= this; objbook.Show(); private void tsbtnIssue_Click(object sender, EventArgs e) if

35、 (this.checkchildfrm(frmIssueBook) = true) return; frmIssueBook issuebook = new frmIssueBook(); issuebook.MdiParent= this; issuebook.Show(); private void tsbtnExit_Click(object sender, EventArgs e) Application.Exit(); private void 退出ToolStripMenuItem1_Click(object sender, EventArgs e) Application.Ex

36、it(); private void 退出ToolStripMenuItem_Click(object sender, EventArgs e) Application.Exit(); private void FrmMain_Load(object sender, EventArgs e) this.tsbtnAddBook.Enabled = false; this.mnuAddBook.Enabled = false; this.mnuUpdateBook.Enabled = false; 图书查询实现代码using System;using System.Collections.Gen

37、eric;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;namespace BookManage public partial class frmSearchBook : Form public frmSearchBook() InitializeComponent(); private void btnSerch_Click(object sender, EventArgs e)

38、string cbo1 = this.cboOR.Text; string cbo2 = this.cboAnd.Text; string booktype = cboType.Text; string bookname = this.txtName.Text; string bookcontent = this.txtContent.Text; string sql = select * from bookInfo where BookType= + booktype + + cbo1 + BookName like % + bookname + % + cbo2 + BookContent

39、 like % + bookcontent + %; DataSet Myds = DataAccess.GetDataSetBySql(sql); DataTable table = Myds.Tables0; this.dgvSearchBook.DataSource = table; private void frmSearchBook_Load(object sender, EventArgs e) DataSet Myds = DataAccess.GetDataSetBySql(select distinct BookType from bookInfo); DataTable table = Myds.Tables0; for (int i = 0; i 0) MessageBox.Show(此书有借阅,不能删除); return; else string sql = delete from bookInfo where BookID= + this.txtbID.Text + ; if (DataAccess.UpdateDataTable(sql) MessageBox.Show(删除成功, 提示, MessageBoxButtons.OK); else MessageBox.Show(删除失败, 提示, MessageBoxButtons.OK);

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!