资源简介
具体要解决的问题如下:
图书管理系统设计
图书管理系统其实是一个很复杂的信息管理系统,它包括很多分类、检索等方面的内容。因为其复杂性,建立这样一个系统更加能体现出运用SQL Server数据库进行数据处理的优越性。本课题将实现一个简化的图书管理系统的功能。
1.系统功能设计
(1)信息录入功能
1)添加新图书信息。当图书馆收藏新图书时,系统向用户提供新图书信息录入功能,由于同一种书可能会有多本,因此,新图书的信息有两类:某一个ISBN类别的图书信息,包括:ISBN书号、图书类别、书名、作者、出版社、出版日期、价格、馆藏数量、可借数量、图书简介;另一个具体到每一本书的信息,包括:ISBN书号、图书书号、是否可借。每一个ISBN书号和同一个ISBN书号的多本书之间是一对多的关系,每一本书的图书书号是唯一的。
2)添加读者信息。用于登记新读者信息。包括:借书证号、姓名、性别、身份证号、职称、可借数量、已借数量、工作部门、联系电话等。
3)借阅信息。用于登记读者的借阅情况信息。包括:借书证号、借阅书号、借出日期、借阅期限、归还日期等信息。归还日期为空值表示该图书未归还。
(2)数据修改和删除功能
1)修改和删除图书信息。图书被借出时,系统需要更新图书信息的可借数量,当可借数量为0时,表示该图书都已被借出。当输入的图书信息有错误或需要进行必要更新时,可以修改图书信息;当一种图书所有馆藏图书都已损毁或遗失并且不能重新买到时,该图书信息需要删除。
2)修改和删除读者信息。当读者的自身信息发生变动,如部门间调动或调离本单位,或违反图书馆规定需要限制其可借阅图书数量时,需要修改读者信息。
3)还书处理。读者归还图书时,更新图书借阅信息表中的归还日期,读者信息表中的已借数量及ISBN类别信息表中该图书的可借数量。
(3)查询和统计功能
1)图书查询功能。根据图书的各种已知条件来查询图书的详细信息,如书名、作者、出版社、ISBN书号等支持模糊查询。
2)读者信息查询。输入读者的借书证号、姓名、工作部门等信息,查询读者的基本信息。对查询到的每一个读者,能够显示其未归还的图书编号和书名。
3)查询所有到期未归还的图书信息。要求结果显示图书编号、书名、读者姓名、借书证号码、借出日期等信息。
4)统计指定读者一段时间内的某类图书或所有类别图书借阅次数及借阅总次数。
2.数据表的创建
根据功能要求的说明创建下列数据表:
(1)图书ISBN类别信息表
图书ISBN类别信息表包括以下字段:
ISBN书号、图书类别、书名、作者、出版社、出版日期、价格、馆藏数量、可借数量、图书简介。
(2)图书信息表
图书信息表包括以下字段:
ISBN书号、图书书号、是否可借。
(3)读者信息表
读者信息表包括以下字段:
借书证号、姓名、性别、出生年月、身份证号、职称、可借数量、已借数量、工作部门、家庭地址、联系电话。
(4)借阅信息表(图书-读者关系)
借阅信息表包括以下字段:
借书证号、借阅书号、借出日期、借阅期限、归还日期。
3.数据库完整性设计
设计者应认真分析和思考各个表之间的关系,合理设计和实施数据完整性原则。
1) 给每个表实施主键及外键约束。
2) 设定缺省约束。如性别。
3) 设置非空约束如图书信息表中的书名。
4) 实施CHECK约束。如ISBN类别表中的可借数量小于馆藏数量。
5) 实施规则。如身份证号码必须为15为或18位。
4.SQL Server数据库对象设计
1)设计一个存储过程,以图书编号为输入参数,返回借阅该图书但未归还的读者姓名和借书证号。
2)读者资料查询:设计一个有多个输入参数的存储过程,返回读者的详细信息。设计另一存储过程并以读者借书证号为输入参数,返回该读者未归还的图书名称和图书编号。
3)到期图书查询:设计一个视图,返回所有逾期未归还的图书的编号、书名、读者姓名等信息。
4)统计图书借阅次数:设计一个以两个日期作为输入参数的存储过程,计算这一段时间内各类别图书被借阅的次数,返回图书类别、借阅次数的信息。
5)加快数据检索速度,用图书编号为图书信息表建立索引。
6)为读者信息表创建一个删除触发器,当一个读者调出本单位时,将此读者的资料从读者信息表中删除。注意实施业务规则:有借阅书的读者不得从读者信息表中删除。
7)借阅处理:为借阅信息表设计INSERT触发器,在读者借阅时更改ISBN类别信息表,且可借数量减1,图书信息表是否可借列的值变为“不可借”,读者信息表中该类读者已借阅数加1。
8)还书处理:为借阅信息表设计UPDATE触发器,在该表的归还日期列被更改后,将图书信息表的是否可借列的值变为“可借”,读者信息表中已借数量减1及ISBN类别信息表中可借数量加1。
代码片段和文件信息
using System;
using System.Collections.Generic;
using System.Text;
using System.Data .SqlClient;
using System.Data;
namespace ClassLibrary
{
public class Dbconnection
{
///
/// SQL-server 数据库连接
///
/// SqlConnection myConnection
public static SqlConnection Dblink()
{
string connectionString = “server=(local);database =Library;integrated security=true“;
SqlConnection myConnection = new SqlConnection(connectionString);
//SqlCommand command = new SqlCommand(connectionString);
return myConnection;
}
///
/// 执行SQL语句
///
///
/// int number
public int ExeInfochange(string sql)
{
try
{
SqlConnection myConnection = Dblink();
SqlCommand myCommand = myConnection.CreateCommand();
myCommand.CommandText = sql;
myConnection.Open();
int number = myCommand.ExecuteNonQuery();
myConnection.Close();
myConnection.Dispose();
return number;
}
catch (Exception)
{
return 0;
}
}
///
/// 执行 Select 语句
///
///
///
public object ExecuteSelect(string sql)
{
try
{
SqlConnection myConnection = Dblink();
SqlCommand myCommand = myConnection.CreateCommand();
myCommand.CommandText = sql;
myConnection.Open();
int number = Convert .ToInt32(myCommand.ExecuteScalar());
myConnection.Close();
myConnection.Dispose();
return number;
}
catch (Exception)
{
return 0;
}
}
///
/// 获取数据集
///
///
/// DataSet ds
public DataSet ds(string str1)
{
string sql = str1;
try
{
SqlConnection myConnection = Dblink();
SqlCommand myCommand = myConnection.CreateCommand();
myCommand.CommandText = sql;
myConnection.Open();
SqlDataAdapter myDataReader = new SqlDataAdapter();
myDataReader.SelectCommand = myCommand;
DataSet ds = new DataSet();
myDataReader.Fill(ds);
myConnection.Close();
myConnection.Dispose();
return ds;
}
catch (Excepti
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 20480 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\bin\Debug\ClassLibrary.dll
文件 19968 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\bin\Debug\ClassLibrary.pdb
文件 1093632 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\bin\Debug\Interop.Excel.dll
文件 217088 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\bin\Debug\Interop.Microsoft.Office.Core.dll
文件 57344 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\bin\Debug\Interop.VBIDE.dll
文件 2972 2008-12-08 08:44 图书管理系统(二) 1.1 (01)\ClassLibrary\ClassLibrary.csproj
文件 3102 2009-01-01 20:20 图书管理系统(二) 1.1 (01)\ClassLibrary\Dbconnection.cs
文件 6937 2008-12-31 03:37 图书管理系统(二) 1.1 (01)\ClassLibrary\Dbinfoshow.cs
文件 417 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\obj\ClassLibrary.csproj.FileList.txt
文件 1257 2008-12-28 20:25 图书管理系统(二) 1.1 (01)\ClassLibrary\obj\ClassLibrary.csproj.FileListAbsolute.txt
文件 726 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\obj\Debug\ClassLibrary.csproj.ResolveComReference.cache
文件 20480 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\obj\Debug\ClassLibrary.dll
文件 19968 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\obj\Debug\ClassLibrary.pdb
文件 1093632 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\obj\Debug\Interop.Excel.dll
文件 217088 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\obj\Debug\Interop.Microsoft.Office.Core.dll
文件 57344 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\ClassLibrary\obj\Debug\Interop.VBIDE.dll
文件 16384 2009-01-01 15:33 图书管理系统(二) 1.1 (01)\ClassLibrary\obj\Debug\Refactor\ClassLibrary.dll
文件 1327 2008-11-21 16:39 图书管理系统(二) 1.1 (01)\ClassLibrary\Properties\AssemblyInfo.cs
文件 513 2008-12-08 12:25 图书管理系统(二) 1.1 (01)\图书管理系统(二)\app.config
文件 20480 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\ClassLibrary.dll
文件 19968 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\ClassLibrary.pdb
文件 1093632 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\Interop.Excel.dll
文件 217088 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\Interop.Microsoft.Office.Core.dll
文件 57344 2009-01-01 20:36 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\Interop.VBIDE.dll
文件 16384 2008-12-08 13:11 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\LibraryReport1.rpt
文件 933888 2009-01-01 20:37 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\图书管理系统(二).exe
文件 513 2008-12-08 12:25 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\图书管理系统(二).exe.config
文件 585216 2009-01-01 20:37 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\图书管理系统(二).pdb
文件 5632 2005-12-08 14:51 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\图书管理系统(二).vshost.exe
文件 513 2008-12-08 12:25 图书管理系统(二) 1.1 (01)\图书管理系统(二)\bin\Debug\图书管理系统(二).vshost.exe.config
............此处省略204个文件信息
- 上一篇:拱猪扑克牌游戏C#源码
- 下一篇:c#宾馆管理系统实现—功能全
相关资源
- C#版本图书管理系统.rar
- C#语言基于SQL server 的图书管理系统
- ASP.NET图书管理系统课程毕业设计源码
- C#图书管理系统源码(含数据库)-附
- 图书管理系统 c# asp .net 图书管理系统
- C#图书管理系统-----
- C#图书管理系统,主要treeview和listvi
- 计算机专业 c#图书管理系统
- C#图书管理系统三层架构含数据库文件
- C#图书管理系统三层架构
- c#图书管理系统C#源码和SQL数据库
- C#图书管理系统含数据库、文档
- 图书管理系统 C# Visul studio.NET( 含源
- C#编写的图书管理系统源代码
- 基于三层架构的Winform图书管理系统
- c#做的简单图书管理系统
- ASP.NET 图书管理系统(毕业设计)
- C#图书管理系统源码20131205
- 图书管理系统源码 C#.net
- 课程设计——图书馆图书管理系统
- asp.net三层架构的图书管理系统
- Windows程序设计--C#--图书管理系统.zi
- 图书管理系统(c#+sql2008)
- C#图书管理系统项目源码.zip
- 基于c#的图书管理系统
- 毕业论文基于Web的图书管理系统
- c# winform图书管理系统
- 数字图书管理系统
- asp.net 图书管理系统+毕业论文
- C#图书管理系统.rar
评论
共有 条评论