图书管理系统的sqlserver数据库设计示例

首先,在写数据库时需要遵循以下几个原则:

    数据库的命名规范:

方便代码的交流和维护
             不影响代码的效率,不与大众习惯冲突
             使代码更美观,阅读更方便
             使代码的逻辑更清晰,更易于理解

术语的定义:

Pascal方法:将标识符的首字母和后面连接的每个单词的首字母都大写  ,可以对三字母或更多的字符的标识符使用。例如:BackColor
             Camel方法:标识符的首字母小写,而后面连接的单词首字母都大写。例如:backColor

基本原则:

以大小写敏感编写SQL语句
            尽量使用Unicode数据类型
            优先使用参数化SQL查询代替拼接SQL查询
            禁止使用拼音+英语的方式来命名SQL对象或变量
            尽量使用存储过程代替SQL语句 
           大写t-sql语言的所有关键字,谓词和系统函数

其次:

对数据库进行分析

1.分析数据库,根据图书管理系统的需求分析,列出表

图书类别:主要包括图书的编号,类别名称等
            图书基本信息:主要包括图书编号,图书名称,类别编号等
            读者类别:主要包括类别编号,类别名称,借书最大量等
            读者基本信息:主要包括读者编号,读者姓名,性别,住址,读者类别
            借阅表:主要包括记录编号,读者编号,图书编号,借出日期,还入日期。

2。根据分析的数据库画出实体图

图书类别:

图书基本信息:

读者类别:

读者基本信息:

借阅表:

3.画出数据库E-R图

4.数据表关系图:

5.根据需求,给出数据字典

6.对数据库进行增、删、改、查相关操作,编写sql脚本实现。

CREATE DATABASE BMS

IF OBJECT_ID(N't_booktype',N'U') IS NOT NULL
	DROP TABLE t_booktype
CREATE TABLE t_booktype(
	typeno int primary key not null,
	typename varchar(30) not null
)

IF OBJECT_ID(N't_books',N'U') IS NOT NULL
	DROP TABLE t_books
CREATE TABLE t_books(
	bookno int primary key not null,
	bookname varchar(30) not null,
	typeno int not null
)

IF OBJECT_ID(N't_readertype',N'U') IS NOT NULL
	DROP TABLE t_readertype
CREATE TABLE t_readertype(
	readertypeno int primary key not null,
	readername varchar(30) not null,
	lendnumber int not null
)

IF OBJECT_ID(N't_readerinfo',N'U') IS NOT NULL
	DROP TABLE t_readerinfo
CREATE TABLE t_readerinfo(
	readerno int primary key not null,
	readername varchar(30) not null,
	readeraddress varchar(30) not null,
	readertypeno int not null
)

IF OBJECT_ID(N't_lendbook',N'U') IS NOT NULL
	DROP TABLE t_lendbook
CREATE TABLE t_lendbook(
	recordno int primary key not null,
	readerno int not null,
	bookno int not null,
	lendtime datetime ,
	returntime datetime
)

INSERT INTO t_booktype
VALUES('1005','悬疑类')

INSERT INTO t_books
VALUES('1025','盗墓笔记','1005')

INSERT INTO t_readertype
VALUES('0005','黄秋萍',20)

INSERT INTO t_readerinfo
VALUES('0005','黄秋萍','南昌市','0005')

INSERT INTO t_lendbook
VALUES('0005','0002','1013','2004-07-28','2004-11-16')

SELECT *
FROM t_books

UPDATE t_books
SET bookname='深入理解计算机系统'
WHERE bookno='1001'

UPDATE t_readertype
SET readername='吴娇'
WHERE readertypeno='0001'

SELECT *
FROM t_readerinfo

--查询图书名字
SELECT bookname
FROM t_books

--查询图书类别
SELECT typename
FROM t_booktype

--查询名字叫吴娇的借书记录

SELECT t_readerinfo.readername,t_lendbook.lendtime,t_lendbook.returntime
FROM t_readerinfo join t_lendbook on t_readerinfo.readerno=t_lendbook.readerno
WHERE t_readerinfo.readername='吴娇'

这里仅进行了部分代码的实现。

如有哪里不正确望指出!

到此这篇关于图书管理系统的sqlserver数据库设计示例的文章就介绍到这了,更多相关图书管理系统 sqlserver数据库设计内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • MySQL 查找价格最高的图书经销商的几种SQL语句

    mysql> use test; Database changed mysql> CREATE TABLE shop ( -> article INT(4) UNSIGNED ZEROFILL DEFAULT '0000' NOT NULL, -> dealer CHAR(20) DEFAULT '' NOT NULL, -> price DOUBLE(16,2) DEFAULT '0.00' NOT NULL, -> PRIMARY KEY(article, deal

  • PHP+MySQL使用mysql_num_rows实现模糊查询图书信息功能

    本文实例讲述了PHP+MySQL使用mysql_num_rows实现模糊查询图书信息功能.分享给大家供大家参考,具体如下: 一.代码 td{ font-size:9pt; } .style2 {color: #FFFFFF} <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html>

  • 图书管理系统的sqlserver数据库设计示例

    首先,在写数据库时需要遵循以下几个原则:     数据库的命名规范: 方便代码的交流和维护              不影响代码的效率,不与大众习惯冲突              使代码更美观,阅读更方便              使代码的逻辑更清晰,更易于理解 术语的定义: Pascal方法:将标识符的首字母和后面连接的每个单词的首字母都大写  ,可以对三字母或更多的字符的标识符使用.例如:BackColor              Camel方法:标识符的首字母小写,而后面连接的单词首字母

  • Java实战之基于I/O流设计的图书管理系统

    一.前言 当前,我还没有学到数据库相关的知识,想要完全通过Java来完成一个可以存储数据的图书馆管理系统就只能使用I/O流的知识,将内容都保存到文件中,再进行增删改查的操作,这就很考验我们的Java基础知识掌握能力. 二.项目介绍 Java基本语法的掌握 流程控制语句的熟练使用 面向对象思想的理解 能否熟练使用封装.继承.多态 接口.异常的熟悉 集合的使用 是否熟悉掌握I/O流相关操作 三.项目说明 传统的人工管理图书馆流程繁琐,我们需求设计一个图书馆管理系统来方便学生借书以及管理员管理书籍 系

  • 使用java springboot设计实现的图书管理系统(建议收藏)

    目录 前言 背景意义 数据库设计 功能截图 代码实现 前言 随着网络技术的发展.计算机应用水平广泛提高,原来系统的时效性.数据的正确性.操作的方便性上都存在不足,已影响到系统的正常使用.经过考察比较,决定自己对图书管理系统重新设计,使系统能利用软件开发技术的成果,方便图书的管理.图书管理系统是典型的信息管理系统.系统介绍了图书系统的开发过程,设计中遇到的问题及解决方法以及提高当前应用程序或系统开发进度和改善工作性能.利用其提供的各种面向对象的开发工具首先在短时间内建立系统应用原型然后对初始原型系

  • 利用java和sqlserver建立简易图书管理系统的完整步骤

    目录 1.所需功能: 2.流程: 3.环境及其语言: 4.数据库建立 5.操作: 数据库连接:sql.T3.Test1.java 选择需要的操作:sql.T3.Test1.java 1.游览所有图书 2.查找书籍 3.建立新图书 4借出图书 5. 归还图书删除某一图书 6.删除某一图书 释放连接: sql.T1.JDBCUtil.java 总结 1.所需功能: 游览所有图书.查找书籍.建立新图书,借出和归还图书,删除某一图书 2.流程: 数据库连接 选择需要的操作 释放连接 3.环境及其语言:

  • JavaSE实现图书管理系统的示例代码

    目录 前言 1. 项目需求 2. 实现思路 3. 代码实现 包的设计 book包 operations包 user包 4. 实现效果 前言 这篇博客是在学习了一部分Java基础语法之后的练习项目,通过这个小项目的练习,对Java中的类和对象,抽象类和接口,面向对象的继承.多态和封装.组合等进行熟悉理解:抽象出不同的对象,将对象进行合理的设计,完成对象之间的交互,面向对象进行编程. 1. 项目需求 图书管理系统,面向管理员和普通用户使用,对管理员的开放的功能有:添加图书,删除图书,查找图书,显示图

  • C# Ado.net实现读取SQLServer数据库存储过程列表及参数信息示例

    本文实例讲述了C# Ado.net读取SQLServer数据库存储过程列表及参数信息的方法.分享给大家供大家参考,具体如下: 得到数据库存储过程列表: select * from dbo.sysobjects where OBJECTPROPERTY(id, N'IsProcedure') = 1 order by name 得到某个存储过程的参数信息:(SQL方法) select * from syscolumns where ID in (SELECT id FROM sysobjects

  • C语言图书管理系统课程设计

    这是本人大一第二学期初C语言课程设计的作品,嘿嘿,本来以为已经找不到原稿了,今天无意中竟然在QQ网络硬盘中找到了当初的teta版,发布于此,以作纪念. C 源代码如下: #include<stdio.h> #include<stdlib.h> #include<string.h> struct book{ char book_name[30]; int bianhao; double price; char author[20]; char state[20]; cha

  • MySQL系列数据库设计三范式教程示例

    目录 一.数据库设计三范式相关知识说明 1.什么是设计范式? 2.为什么要学习数据库的三个范式? 3.三范式都有哪些? 二.数据库表的经典设计方案 一对一怎么设计? 一.数据库设计三范式相关知识说明 1.什么是设计范式? 设计表的依据,按照这三个范式设计出来的表,不会出现数据的冗余. 2.为什么要学习数据库的三个范式? 数据库的设计范式是数据库设计所需要满足的规范,满足这些规范的数据库是简洁的.结构明晰的,同时,不会发生插入(insert).删除(delete)和更新(update)操作异常.反

  • Java图书管理系统课程设计

    本文实例为大家分享了Java图书管理系统的具体代码,供大家参考,具体内容如下 大二上学期做的一个Java课程设计,总分为四个Java文件,AllBook,AllBorrow,AllStudent,Tushu. 本系统是一个面向图书馆的管理系统,具有一定的实用性.它主要完成了图书的基本操作功能,全校学生信息的相关基本操作,以及对图书的借阅归还管理.本系统采用当前流行的面向对象的JAVA语言开发工具eclipse来完成整个系统的设计.系统在设计过程中不可避免地遇到了各种各样的问题,由于整个系统完全都

  • C语言实现图书管理系统(文件数据库)

    本文实例为大家分享了C语言实现图书管理系统的具体代码,供大家参考,具体内容如下 简介 c语言的一个大作业,发上来纪念下嘿嘿.写的不是很好,很多东西都揉在一起来,不过注释写的也挺多,希望能帮到有需要的朋友. 题目要求 简单文件数据库-模拟图书馆管理系统 涉及知识点:文件读写.内存管理.结构体定义.基本数据结构.高级格式化输入输出 要求: 编写一个程序模拟图书管理系统.用户分为管理员和读者两类,分别显示不同文本格式菜单,通过菜单项对应数字进行选择.读者菜单包括借书.还书.查询等功能.管理员菜单包括图

随机推荐