200分2天内求大学本科数据库课程设计!急!急!

200分2天内求大学本科数据库课程设计!急!急!,第1张

一、课程设计的内容

本课程设计要采用本课程中学习的数据库设计方法,运用其基本思路与主要图表工具完成“企业报刊订阅管理系统”数据库应用系统。完成信息需求分析与数据库的概念设计、逻辑设计、物理设计以及处理功能设计,用SQL Sever的数据库管理系统、JSP开发工具实现该系统,并运行、评价、改进之;在此基础上严格按课程设计教学大纲所附报告提纲撰写课程设计报告。通过本课程设计进一步弄懂数据库系统及其相关的基本概念,理解数据库系统的系统结构、主要特点,掌握数据库设计的原理、方法及其基本过程,初步具备数据库应用设计的能力,初步形成运用数据库应用系统解决管理决策中的实际问题的基本素质。

二、课程设计的要求与数据

要求学生结合所学管理知识,在借鉴课堂教学案例、了解家人或亲友所从事的业务及其流程的基础上,参考有关资料,选择自己了解的一项业务,运用课堂所学数据库系统与数据库设计知识,完成信息需求分析、数据库概念设计、逻辑设计、物理设计,实现完成该业务的数据库应用系统,并运行、评价改进之,最后要写出课程设计报告。

三、课程设计应完成的工作

要求学生按照《数据库应用课程设计》教学大纲完成一个数据库应用系统,并撰写相应的课程设计报告,主要内容包括:

概述:系统的基本任务,主要业务,开发目标

1. 需求分析

2. (数据库)概念(模型)设计

3. (数据库)逻辑(模型)设计

4. 数据库物理设计与数据库保护设计

5. 处理功能设计

6. 数据库应用系统的实现

7. 数据库应用系统运行

四、课程设计进程安排

序号 设计各阶段内容 地点 起止日期

五、应收集的资料及主要参考文献

[1] 王 珊、陈 虹编著,数据库系统原理教程,清华大学出版社,2003.

[1] 金银秋主编,数据库原理与设计,科学出版社,2000.

[2] 李建中 王珊,数据库系统原理,电子工业出版社,1998.

[3] 李大友,数据库原理及应用(第二版),清华大学出版社,2000

发出任务书日期: 年月日指导教师签名:

计划完成日期: 年月日基层教学单位责任人签章:

主管院长签章:

目录

概述 …………………………………………………………………4

1. 需求分析…………………………………………………………4

1.1用户需求……………………………………………………………………4

1.2业务流程分析………………………………………………………………4

1.3信息需求分析………………………………………………………………5

1.4功能需求分析………………………………………………………………6

2. (数据库)概念(模型)设计…………………………………7

3. (数据库)逻辑(模型)设计…………………………………9

3.1 一般逻辑模型设计…………………………………………………………9

3.2 具体逻辑模型设计…………………………………………………………9

4. 数据库物理设计与数据库保护设计…………………………10

4.1设计索引……………………………………………………………………10

4.2 设计表间关系………………………………………………………………10

4.3完整性设计…………………………………………………………………10

5. 处理功能设计…………………………………………………11

6. 数据库应用系统的实现………………………………………11

7. 数据库应用系统运行…………………………………………11

7.1 写出系统 *** 作使用的简要说明……………………………………………11

7.2 系统实施过程………………………………………………………………11

7.3系统使用结果………………………………………………………………22

7.4系统评价……………………………………………………………………31

企业报刊订阅管理系统

概述

随着社会不断的发展,人们的生活水平越来越高,对知识的和对时事的渴求也越来越高,人们希望能够方便快捷地订阅各种报刊杂志。但是各种各样的报刊名目和详细信息以及订阅,为相关企业的管理造成很大的麻烦。因此网上订阅成为不可或缺的一部分。

本系统就是面向一个企业的报刊订阅管理系统。此系统是一种比较智能化的管理系统,它面向所有企业部门的职工用户,但具有比较高的安全性能。它能够实现报刊订阅的基本功能,包括新报刊信息的录入、订阅、查询等 *** 作以及后台数据库的备份和恢复。用户合法注册后必须输入有效密码才能成功进入此系统,可以进行订阅报刊,查询信息,统计信息等 *** 作。对于非法 *** 作,系统有识别和防护措施。

1. 需求分析

1.1 用户需求:

本系统就是面向一个企业的报刊订阅管理系统。此系统是一种比较智能化的管理系统,它面向所有企业部门的职工用户,但具有比较高的安全性能。它能够实现报刊订阅的基本功能,包括新报刊信息的录入、订阅、查询等 *** 作以及后台数据库的备份和恢复。用户合法注册后必须输入有效密码才能成功进入此系统,可以进行订阅报刊,查询信息,统计信息等 *** 作。对于非法 *** 作,系统有识别和防护措施。

订阅信息处理的特点是订阅信息处理量比较大,所管理的信息信息种类繁多,而且订阅单、编辑单的发生量特别大,关联信息多,查询和统计的方式各不相同。因此在管理上实现起来有一定因难。

本系统在设计过程中,为了克服这些困难,需要使程序代码标准化,软件统一化,确保软件的可维护性和实用性;删除不必要的管理冗余,实现管理规范化、科学化;界面友好、简单化,做到实用、方便,尽量满足报刊订阅中员工的需要。

1.2 业务流程分析:

本系统主要面向的用户有系统管理员、读者。下面分角色对该系统的不同 *** 作范围做说明。

本系统主要有以下功能模块:

(1)登陆功能:登陆系统为身份验证登录。分为管理员登录和一般用户登录。分别通过不同的用户名和密码进入报刊订阅管理界面,新的用户需要注册。

(2)录入新信息功能:对于管理员,包括新用户信息和新报刊信息的录入功能,信息一旦提交就存入到后台数据库中;普通用户自行注册进行可以修改个人信息。

(3)订阅功能:用户可以订阅报刊,系统自动计算所需金额,并显示在界面上;管理员不可订阅报刊,必须以用户身份订阅报刊。

(4)查询功能:用户可以查询并显示自己所订阅的信息;管理员可以按人员、报刊、部门分类查询。查询出的信息显示在界面上,并且可以预览和打印出结果。

(5)统计功能:管理员可以按用户、部门、报刊统计报刊的销售情况,并对一些重要的订阅信息进行统计;普通用户可以统计出自己的订阅情况,并且可以预览和打印出结果。

(6)系统维护功能:数据的安全管理,主要是依靠管理员对数据库里的信息进行备份和恢复,数据库备份后,如果出了什么意外可以恢复数据库到当时备份的状态,这提高了系统和数据的安全性,有利于系统的维护。

下图为该系统的业务流程图

1.3 信息需求分析

1.3.1 资料收集:业务流程中用到的相关单据主要是报刊信息还有订单信息

报刊信息表:

报刊代号 46-250 报刊名称 IT时代周刊

出版报社 科技出版社

出版周期 半月刊

每月定价 10.00 元/月

分类编号 1001

报刊介绍 《IT时代周刊》是一本深刻解读信息时代商业变革的杂志。除深度报道信息产业的重大新闻外,还报道金融、汽车、股市、零售等传统行业利用IT提升商业与管理的新闻。《IT时代周刊》以调查见深度;以商业故事见功力。是CEO/CIO/CFO以及政府官员、商业领袖首选刊物。

订单信息表:

订单编号 报刊代号 用户编号 订阅日期 订阅月数 份数 *** 作

3003 46-205 3206 2008-7-1 订一月 1 取消订阅

3004 26-306 3108 2008-7-8 订半年 2 取消订阅

3005 72-310 3100 2008-7-9 订一年 1 取消订阅

3006 45-214 2541 2008-7-10 订一季 1 取消订阅

1.3.2 事项分析:根据以上资料中标题、表头等中各栏目名,可以得出相关事项,作为数据项;分析这些数据项,找出组合项、导出项、非结构化数据项,确定基本项。检查是否有要补充的基本数据项,是否有要改进的地方,补充改进之,得出所有基本项。

1.4 功能需求分析:

本系统的主要结构功能图如下:

2. (数据库)概念(模型)设计

基本项构思ERD的四条基本原则:

①原则1 (确定实体):能独立存在的事物,例如人、物、事、地、团体、机构、活动、事项等等,在其有多个由基本项描述的特性需要关注时,就应把它作为实体。

②原则2 (确定联系):两个或多个实体间的关联与结合,如主管,从属,组成,占有,作用,配合,协同等等,当需要予以关注时,应作为联系。实体间的联系可分为一对一、一对多、多对多等三类,在确定联系时还要确定其类型。

③原则3 (确定属性):实体的属性是实体的本质特征。实体应有标识属性(能把不同个体区分开来的属性组),并指定其中一个作为主标识。联系的属性是联系的结果或状态。

④原则4(一事一地):信息分析中得到的基本项要在且仅在实体联系图中的一个地方作为属性出现。

经过上述系统功能分析和需求总结,设计如下面所示的数据项和数据结构。

 管理员表(Adminuser):用于存放管理员的数据记录,包括数据项:管理员名、密码。

 部门表(Department):用来存放部门的相关记录,包括数据项:部门号,部门名。

 用户表(Users):用于存放注册用户的记录,包括数据项:用户账号、密码、真实姓名、身份z号、联系电话,联系地址,部门号(和部门表有关)等。

 报刊类别表(NewspaperClass):用于存放初始的报刊类别记录,包括数据项:分类编号、分类名称。

 报刊信息表(Newspaper):用于存放报刊记录,包括数据项:报刊代号、报刊名称、出版报社、出版周期、季度报价、内容介绍、分类编号(和报刊类别表有关)等。

 订单表(Order):用于存放用户下达的订阅报刊的基本信息,包括数据项:订单编号、用户编号(用户表的主码)、报刊代号(报刊信息表的主码)、订阅份数、订阅月数等。

根据上面的设计规划出来的实体有部门实体、管理员实体、用户实体、报刊类别实体、报刊信息实体和订单实体。

部门实体的E-R图如下图所示: 管理员实体的E-R图如下图所示:

用户实体的E-R图如下图所示:报刊信息实体的E-R图如下图所示:

订单实体的E-R图如下图所示: 报刊类别实体的E-R图如下图所示:

所有实体之间的的关系E-R图如下图所示:

3. (数据库)逻辑(模型)设计

3.1 一般逻辑模型设计:

关系模型的逻辑结构是一组关系模式的集合。将E-R图转换为关系模型就是要将实体型、实体的属性和实体型之间的联系转换为关系模式。

由ERD导出一般关系模型的四条原则;

①一个1:1联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系模式合并。如果软换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,每个实体的码均是该关系的候选码。如果与某一端实体对应的关系模式何明,则需要在该关系模式的属性中加入另一个关系模式的码和联系本身的属性。

②一个1:n联系可以转换为一个独立的关系模式,也可以与n端对应的关系模式合并。如果转换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,而关系的码为n端实体的码。

③一个m:n联系转换为一个关系模式。与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,各实体的码组成关系的码或关系码的一部分。

④3个或3个以上实体间的一个多元联系可以转换为一个关系模式。与该多元联系项链呢的各实体的码以及联系本身的属性均转换为关系的属性,各实体的码组成关系的码或关系码的一部分。

根据以上原则将E-R图转换成的关系模式如下:

部门(部门号,部门名称)

用户(用户账号,密码,用户真实姓名,联系电话,联系地址,部门号)

管理员(管理员名,密码)

报刊类别(分类编号,分类名称)

报刊(报刊代号,报刊名称,出版报社,出版周期,每月订价,内容介绍,分类编号)

订单(用户编号,报刊代号,订阅份数,订阅月数,订阅总额)

3.2 具体逻辑模型设计:

在SQL Server2000数据库中,首先创建newspaper数据库,然后根据数据库的逻辑结构分析创建表4-1━4-6的6张数据表。在前台访问数据库阶段设置了用户和密码,用户为sa,密码为空。

表4-2 department部门表结构

字段名称 字段类型 允许空 说明

depNumber(主码) Char(10) 否 部门号

depName Char(50) 是 部门名称

表4-3 users用户表结构

字段名称 字段类型 允许空 说明

userNo(主码) Char(10) 否 用户帐号

userName Char(20) 是 真实姓名

passWord Char(10) 否 用户密码

address Char(150) 是 用户联系地址

phone Char(20) 是 用户联系电话

depNumber Char(10) 否 用户所属部门号

表4-3 newspaperClass报刊分类表结构

字段名称 字段类型 允许空 说明

classid(主码) Int(4) 否 报刊分类编号

className Char(30) 是 报刊分类名称

表4-4 newspaper报刊表结构

字段名称 字段类型 允许空 说明

newsNo(主码) Char(10) 否 报刊代号

newsName Char(40) 否 报刊名称

classid Int(4) 否 报刊分类编号

publish Char(150) 是 出版报社

pubPeriod Char(30) 是 出版周期

content Char(4000) 是 内容介绍

price Float(8) 否 每月报价

表-6 book订单表结构

字段名称 字段类型 允许空 说明

userNo(主码) Char(10) 否 用户帐号

newsNo(主码) Char(10) 否 报刊代号

orderAmount Int(4) 否 订阅份数

orderMonth Int(4) 否 订阅月数

totalPrice Float(8) 是 订阅总额

表4-1 adminuser管理员表结构

字段名称 字段类型 允许空 说明

adminUser(主码) Char(20) 否 管理员用户名

adminPass Char(10) 否 管理员密码

4. 数据库物理设计与数据库保护设计

4.1设计索引:我们可以在最经常查询的列上建立索引以提高查询效率。

而在这个系统中,我们经常要按用户账号,按报刊代号,按部门查询,所以,我们可以为这三个表建立索引,建立所以的SQL语句如下,这几个都是字符型

Create unique index userNum on users(userNo)

Create unique index departNum on department(depNumber)

Create unique index newsNum on newspaper(newsNO)

4.2 设计表间关系:

4.3完整性设计列出主要字段完整性的字段名、完整性约束条件;列出记录完整性约束及其约束条件;列出参照完整性表。

主要字段的完整性字段名和参照完整性表可以参照上图各个表之间的关系来看。

比如建立报刊表newspaper时,要求报刊代号在100~99999之间,报刊名称和每月定价不能取空值,报刊类别是报刊类别表的主键,则

Create table user

(userNo char(10) constraint C1 check(newsNo between 100 and 99999),

newsName char(40) constraint C2 not null,

classid int(4) constraint C3 not null,

publish char(150),pubPeriod char(30),content char(4000),

price float(8) not null,

constraint C4 foreign key(classid) references newspaperclass(classid) )

4.4在有多个用户 *** 作时,考虑用户授权与安全性控制。

因为这个报刊订阅系统由多个用户使用,分为管理员和用户,他们拥有不同的权限和安全性控制。所以在权限设置方面,采用管理员和用户分别使用用户名和密码进入他们能使用权限范围里的界面。管理员登陆系统后,可以添加、修改用户和报刊的信息,可以对订单进行查询和统计,并且可以把查询统计的结果进行预览和打印出来,还要对数据库系统进行维护,适时备份数据库,一旦数据库遇到问题,可以恢复到最近备份的状态,减少不必要的损失。

用户登录,用户使用该系统前需要进行注册,他应该是该企业某个部门下面的员工,所以他需要输入他的部门号等信息,注册成功后,登录到系统,可以修改自己的信息还有订阅报刊,但由于权限的限制,他只能查看和统计自己的订单信息。

5. 处理功能设计

5.1 主控模块设计:

使用本系统,首先它会自动d出“欢迎使用本系统”的欢迎界面,然后跳转到用户身份验证界面,选择管理员的身份进入,有录入(录入报刊信息、录入用户信息),查询,统计(统计用户、统计、报刊订单),系统维护(备份数据库、恢复数据库),注销,退出等菜单可使用,没注册的用户可进入注册界面进行注册,然后返回登录界面登录,进入后有欢迎界面,有订阅、查询、统计、修改、注销、退出等菜单可使用。

6. 数据库应用系统的实现

6.1 数据库及其表结构的建立:按照上面的逻辑分析见表

6.2数据输入:在建好的各个表中输入数据,要符合数据的约束条件

7. 数据库应用系统运行

7.1 写出系统 *** 作使用的简要说明

本系统的运行需要安装PowerBuilder9.0和SQL Server2000软件。 *** 作该系统,首先把备份的数据库还原出来,导入SQL Server中,然后打开该系统,连接上还原出来的数据库,再运行,就可以了。

7.2 系统实施过程

(1)打开PowerBuilder,新建一个工作区,命名为newspaper

(2)新建一个Application,取名newspaper,然后点击工具栏上的DB Profile,新建一个MSS Microsoft SQL Server,填入Profile Name,服务器名,用户名,密码,数据库,如下图,然后输入连接数据库的主要代码:

open(w_welcome)

// Profile newspaper

SQLCA.DBMS = "MSS Microsoft SQL Server"

SQLCA.Database = "newspaper"

SQLCA.ServerName = "CHINA-41CD782EF"

SQLCA.LogId = "sa"

SQLCA.LogPass=""

SQLCA.AutoCommit = False

SQLCA.DBParm = ""

connect

if sqlca.sqlcode<>0 then

messagebox("错误","数据库连接错误,程序将关闭!",stopsign!)

return

end if

close(w_welcome)

open(w_login)

(3)制作登录页面w_login,在“确定”按钮输入如下:

“注册”按钮代码:open(w_register) //打开用户注册页面

“退出”按钮代码:close(w_login)//退出本系统

(4)制作注册窗口w_register,在“注册”按钮的代码如下:

“取消”按钮代码:close(w_register)

open(w_login)

(5)制作管理员主菜单w_adminview,建管理员主界面w_adminview,将该菜单放到窗口中

(6)制作用户主菜单w_userview,建用户主界面w_userview,将菜单放到窗口中

(7)制作管理员主菜单里的录入报刊信息窗口w_inmagazine,录入用户信息窗口w_inuser,

制作数据窗口dw_magagrid,dw_magafree,dw_userfree,dw_usergrid,在数据窗口调整好外观,添加控件,并设定相应的动作,分别放到这两个窗口中

这两个窗口功能相识,在窗口中输入:

dw_1.settransobject(sqlca)

dw_1.retrieve()

dw_2.settransobject(sqlca)

dw_2.retrieve()

(8)制作管理员主菜单中的查询订阅信息窗口w_searchorder,制作数据窗口dw_booksearch,将其放入窗体中,在窗口中输入代码:

dw_1.settransobject(sqlca)

dw_1.retrieve()

sle_1.setfocus()

在“查询”按钮中输入代码:

“预览”按钮的代码:

“关闭”按钮代码:close(w_searchorder)

数据窗口字段如下:

(9)制作管理员主菜单中的统计用户订单窗口w_statuser,统计部门订单窗口w_statdept,统计报刊订单窗口w_statnews:制作统计数据窗口dw_statnews,dw_statuser,dw_statdept将dw_statnews,dw_statuser,dw_statdept分别放入w_statnews, w_statuser,w_statdept中;以下仅列出按出按部门统计的代码和界面 (按用户、报刊统计类似,略);

按部门统计代码:

窗口代码:

按部门统计数据窗口:

dw_1.settransobject(sqlca)

dw_1.retrieve()

预览键代码:(与上页预览代码相同)

退出:close(parent)

(10)管理员主菜单中的更改登录在w_adminview中的代码

(11)管理员主菜单中的退出系统在w_adminview中的代码

(12)管理员主菜单中的数据库备份窗口w_backup,“开始备份”按钮的代码如下

在“>>”按钮带输入代码:

(13)管理员主菜单中的数据库恢复窗口w_restore,“开始恢复”按钮的代码如下

在“>>”按钮带输入代码:

在“开始恢复”按钮输入代码:

(14)用户主菜单的订阅报刊窗口w_userorder

该系统中定义了一个全局变量gs_userid,其它窗口界面都可以使用该变量,并显示用户名,用户登录后,它会显示“~~~~,欢迎使用本系统!”的欢迎界面。

窗口代码:

dw_1.settransobject(sqlca)

dw_1.retrieve()

sle_1.setfocus()

sle_2.text=gs_userid

“清空”按钮代码:

sle_1.text=""

sle_3.text=""

sle_5.text=""

“退出”按钮代码:

close(w_userorder)

“订阅”按钮代码:

(14)用户主菜单的查询订单窗口w_usersearch,将订单查找dw_booksearch放到窗口里,在窗口中过过滤器筛选中用户自己的订单信息,一打开就可以看到自己的订单信息,可打印和预览结果

窗口代码:

“预览”和“退出”按钮同上

(15)用户主菜单的查询订单窗口w_userstatis,将用户统计dw_statuser放到窗口里,在窗口中过过滤器筛选中用户自己的订单信息,一打开就可以看到自己的订单信息,可打印和预览结果,窗口代码如下:

用户统计dw_statuser数据窗口如下:

“预览”“退出”按钮略

(16)用户主菜单中的修改用户信息窗口w_usermodify,打开会先显示出你的信息,而用户名这一栏是输入不了的,也就是不能修改用户名,窗口代码如下:

“保存”按钮代码如下:

(17)用户主菜单中的更改登录和退出系统的代码和管理员的一样,这里就省略了。

7.3系统使用结果

打开本系统,首先d出欢迎界面,通常一闪而过,然后到了登录界面,点击“注册”

按确定后,d出“恭喜,您已注册成功!”的对话框。如果这时刷新服务管理器,打开SQL Server企业管理器,打开该数据库的用户表,就可看到刚才注册的用户已经在表中了

然后返回到登陆页面,输入刚才注册到的用户名和密码maishning,123456

登录后,d出一个窗口,有供用户使用的菜单,界面显示“~~~~,欢迎使用本系统”

选择“订阅”菜单,在这个订阅界面,用户可以浏览到所有的报刊信息,要订阅报刊时,用户不需输入用户名与密码,只需输入您要订阅的报刊代号(该报刊代号必须是报刊表中存在的),订阅份数(必须是小于8的整数才有效),然后选择需要订阅的月数(一月、一季、半年或一年)然后点击“订阅”按钮

订阅成功后,系统d出“恭喜!你已成功订阅该报刊,总金额是~~~~”确定后会显示出您所订阅的总额是多少元,按“清空”按钮后可以订阅其它报刊(同样的报刊不可重复订阅)

再订阅其它报刊,然后按“退出”按钮,来到用户主菜单然后选择“查询”菜单,这个数据窗口经过过滤,一打开就直接显示该用户过订阅的订单,可以进行预览和打印。

由于权限的限制,“统计”菜单中的也是只能统计自己订单信息的数据

在“退订”报刊菜单中,可以查看自己的订单,单击“退订”然后“保存”即可完成退订

在“修改”信息菜单中,用户名也是不可输入的文本框,即不可修改用户名,其它信息可以修改,保存后它会自动添加到数据库中

选择菜单上的“注销”,可以用不同的身份进入系统,确定后回到登录界面

以管理员的身份登录,用户名111,密码111,按登录按键,可看到管理员菜单

选择菜单栏中的录入->录入报刊信息,管理员可以大致浏览所有报刊信息,在上面的数据窗口可以查看上一页和下一页的具体内容,并且可以对其进行添加,删除、修改、保存等 *** 作。

录入用户信息页面,基本相似

选择菜单栏中的“查询”->“订单信息”,管理员拥有的权限可以看到所有的订单信息

管理员也可以根据需要分别按部门、按用户、按报刊查询,比如,要查询msishning用户,在文本框中输入关键字,选择单选按钮中的“按部门号”,点击“查询”,结果如下

可对全部订单或查询出来的订单进行预览和打印,方便使用

菜单栏中的“统计”菜单有三个子菜单,管理员可以分别统计用户订单信息、部门订单信息和报刊订单信息, 直接选择就可看到统计结果,比如选择“统计用户订单信息”

可将统计出来的结果进行预览和打印,方便使用,其它两个统计功能相似,略

主菜单中的系统维护->数据库备份,选择备份的位置,然后“开始备份”

主菜单中的系统维护->数据库恢复,选择之前备份的文件,输入路径和数据库名,然后“开始恢复”

7.4系统评价:

我这里有一份答案

已经给你发站内信

SQL是英文Structured Query Language的缩写,意思为结构化查询语言。SQL语言的主要功能就是同各种数据库建立联系,进行沟通。按照ANSI(美国国家标准协会)的规定,SQL被作为关系型数据库管理系统的标准语言。SQL语句可以用来执行各种各样的 *** 作,例如更新数据库中的数据,从数据库中提取数据等。目前,绝大多数流行的关系型数据库管理系统,如Oracle, Sybase, Microsoft SQL Server, Access等都采用了SQL语言标准。虽然很多数据库都对SQL语句进行了再开发和扩展,但是包括Select, Insert, Update, Delete, Create,以及Drop在内的标准的SQL命令仍然可以被用来完成几乎所有的数据库 *** 作。

SQL Server

SQL Server 是一个关系数据库管理系统。它最初是由Microsoft Sybase 和Ashton-Tate三家公司共同开发的,于1988 年推出了第一个OS/2 版本。在Windows NT 推出后,Microsoft与Sybase 在SQL Server 的开发上就分道扬镳了,Microsoft 将SQL Server 移植到Windows NT系统上,专注于开发推广SQL Server 的Windows NT 版本。Sybase 则较专注于SQL Server在UNIX *** 作系统上的应用。

SQL Server 2000 是Microsoft 公司推出的SQL Server 数据库管理系统,该版本继承了SQL Server 7.0 版本的优点,同时又比它增加了许多更先进的功能。具有使用方便可伸缩性好与相关软件集成程度高等优点,可跨越从运行Microsoft Windows 98 的膝上型电脑到运行Microsoft Windows 2000 的大型多处理器的服务器等多种平台使用。

SQL Server 2005?

SQL Server 2005 是一个全面的数据库平台,使用集成的商业智能 (BI) 工具提供了企业级的数据管理。SQL Server 2005 数据库引擎为关系型数据和结构化数据提供了更安全可靠的存储功能,使您可以构建和管理用于业务的高可用和高性能的数据应用程序。

SQL Server 2005 数据引擎是本企业数据管理解决方案的核心。此外 SQL Server 2005 结合了分析、报表、集成和通知功能。这使您的企业可以构建和部署经济有效的 BI 解决方案,帮助您的团队通过记分卡、Dashboard、Web services 和移动设备将数据应用推向业务的各个领域。

与 Microsoft Visual Studio、Microsoft Office System 以及新的开发工具包(包括 Business Intelligence Development Studio)的紧密集成使 SQL Server 2005 与众不同。无论您是开发人员、数据库管理员、信息工作者还是决策者,SQL Server 2005 都可以为您提供创新的解决方案,帮助您从数据中更多地获益。

SQL全称是“结构化查询语言(Structured Query Language)”,最早的是IBM的圣约瑟研究实验室为其关系数据库管理系统SYSTEM R开发的一种查询语言,它的前身是SQUARE语言。SQL语言结构简洁,功能强大,简单易学,所以自从IBM公司1981年推出以来,SQL语言,得到了广泛的应用。如今无论是像Oracle ,Sybase,Informix,SQL server这些大型的数据库管理系统,还是像Visual Foxporo,PowerBuilder这些微机上常用的数据库开发系统,都支持SQL语言作为查询语言。

SQL是高级的非过程化编程语言,允许用户在高层数据结构上工作。他不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统可以使用相同的SQL语言作为数据输入与管理的接口。它以记录集合作为 *** 纵对象,所有SQL语句接受集合作为输入,返回集合作为输出,这种集合特性允许一条SQL语句的输出作为另一条SQL语句的输入,所以SQL语言可以嵌套,这使他具有极大的灵活性和强大的功能,在多数情况下,在其他语言中需要一大段程序实现的一个单独事件只需要一个SQL语句就可以达到目的,这也意味着用SQL语言可以写出非常复杂的语句。

SQL同时也是数据库文件格式的扩展名。

SQL语言包含4个部分:

数据定义(DDL)语言(如CREATE, DROP,ALTER等语句)

数据 *** 纵(DML)语言(INSERT, UPDATE, DELETE语句)

数据查询语言(SELECT语句)

数据控制语言(如GRANT,REVOKE,COMMIT, ROLLBACK等语句)

取自"http://zh.wikipedia.org/wiki/SQL"

SQL(STructured Query Language)是一种资料库查询和程式设计语言,用於存取资料以及查询、更新和管理关联式资料库系统。美国国家标准局(ANSI)与国际标准化组织(ISO)已经制定了 SQL 标准。ANSI 是一个美国工业和商业集团组织,发展美国的商务和通讯标准。ANSI 同时也是 ISO 和 International Electrotechnical Commission(IEC)的成员之一。ANSI 发布与国际标准组织相应的美国标准。1992年,ISO 和 IEC 发布了 SQL 的国际标准,称为 SQL-92。ANSI 随之发布的相应标准是 ANSI SQL-92。ANSI SQL-92 有时被称为 ANSI SQL。尽管不同的关联式资料库使用的 SQL 版本有一些差异,但大多数都遵循 ANSI SQL 标准。SQL Server 使用 ANSI SQL-92 的扩展集,称为 T-SQL,其遵循 ANSI 制定的 SQL-92 标准。

SQL 语言包括两种主要程式设计语言类别的陈述式: 资料定义语言 (DDL)与资料 *** 作语言 (DML)。下面我们将介绍这两类语言。

DDL

DDL 用於定义和管理物件,例如资料库、资料表以及检视表( 第18章 将会解释何谓检视表)。DDL 陈述式通常包括每个物件的CREATE、ALTER 以及 DROP 命令。举例来说,CREATE TABLE、ALTER TABLE 以及 DROP TABLE 这些陈述式便可以用来建立新资料表、修改其属性(如新增或删除资料行)、删除资料表等,下面我们会一一介绍。

CREATE TABLE 陈述式

使用 DDL 在 MyDB 资料库建立一个名为 Customer_Data 的范例资料表,本章后面的例子我们会使用到这个资料表。如前所述,CREATE TABLE 陈述式可以用来建立资料表。这个范例资料表被定义成四个资料行,如下所示:

Use MyDB

CREATE TABLE Customer_Data

(customer_id smallint,

first_name char(20),

last_name char(20),

phone char(10))

GO

这个陈述式能产生 Customer_Data 资料表,这个资料表会一直是空的直到资料被填入资料表内。

ALTER TABLE 陈述式

ALTER TABLE 陈述式用来变更资料表的定义与属性。在下面的例子中,我们利用 ALTER TABLE 在已经存在的 Customer_Data 资料表中新增 middle_initial 资料行。

ALTER TABLE Customer_Data

ADD middle_initial char(1)

GO

现在资料表的定义包括了五个资料行,而不是之前的四个资料行。关於使用ALTER TABLE 的更多细节,请参阅 第15章 。

DROP TABLE 陈述式

DROP TABLE 陈述式用来删除资料表定义以及所有的资料、索引、触发程序、条件约束以及资料表的权限。要删除我们的 Customer_Data 资料表,可利用下列命令:

DROP TABLE Customer_Data

GO

关於 DROP TABLE 陈述式的详细内容,请参阅 第15章 。

DML

DML 利用 INSERT、SELECT、UPDATE 及 DELETE 等陈述式来 *** 作资料库物件所包含的资料。

INSERT 陈述式

INSERT 陈述式用来在资料表或检视表中插入一列资料。例如,如果要在Customer_Data 资料表中新增一个客户,可使用类似以下的 INSERT 陈述式:

INSERT INTO Customer_Data

(customer_id, first_name, last_name, phone)

VALUES (777, "Frankie", "Stein", "4895873900")

请注意 SQL 陈述式中第二行的资料行名称清单,清单上资料行名称的次序决定了资料数值将被放在哪个资料行。举例来说,第一个资料数值将被放在清单列出的第一个资料行 customer_id、第二个资料数值放在第二个资料行,依此类推。由于我们在建立资料表时,定义资料资料行填入数值的次序与现在相同,因此我们不必特意指定栏位名称。我们可以用以下的 INSERT 陈述式代替:

INSERT INTO Customer_Data

VALUES (777, "Frankie", "Stein", "4895873900")

注意

如果使用这种形式的 INSERT 陈述式,但被插入的数值次序上与建立资料表时不同,数值将被放入错误的资料行。如果资料的型别与定义不符,则会收到一个错误讯息。

UPDATE 陈述式

UPDATE 陈述式用来更新或改变一列或多列中的值。例如,一位名称为 Frankie Stein 的客户想要在记录中改变他的姓氏为 Franklin,可使用以下 UPDATE 陈述式:

UPDATE Customer_Data

SET first_name = "Franklin"

WHERE last_name = "Stein" and customer_id= 777

我们在 WHERE 子句中加入 customer_id 的项目来确定其他名称为 Stein 的客户不会被影响-只有customer_id为777的客户,姓氏会有所改变。

--------------------------------------------------------------------------------

说明

当您使用 UPDATE 陈述式时,要确定在 WHERE 子句提供充分的筛选条件,如此才不会不经意地改变了一些不该改变的资料。

--------------------------------------------------------------------------------

DELETE 陈述式

DELETE 陈述式用来删除资料表中一列或多列的资料,您也可以删除资料表中的所有资料列。要从 Customer_Data 资料表中删除所有的列,您可以利用下列陈述式:

DELETE FROM Customer_Data

DELETE Customer_Data

资料表名称前的 FROM 关键字在 DELETE 陈述式中是选择性的。除此之外,这两个陈述式完全相同。

要从 Customer_Data 资料表中删除 customer_id 资料行的值小於100的列,可利用下列陈述式:

DELETE FROM Customer_Data

WHERE customer_id <100

现在我们已经快速浏览了 SQL 提供的 DDL 与 DML 陈述式,接著,下面将介绍 T-SQL。

--------------------------------------------------------------------------------

SELECT 陈述式

SELECT 陈述式用来检索资料表中的资料,而哪些资料被检索由列出的资料行与陈述式中的 WHERE 子句决定。例如,要从之前建立的 Customer_Data 资料表中检索 customer_id 以及 first_name 资料行的资料,并且只想取出每列中 first_name 资料行值为 Frankie 的资料,那麼可以利用以下的 SELECT 陈述式:

SELECT customer_id, first_name FROM Customer_Data

WHERE first_name = "Frankie"

如果有一列符合 SELECT 陈述式中的标准,则结果将显示如下:

customer_id first_name

------------- ------------

777 Frankie

SQL中的五种数据类型

简要描述一下SQL中的五种数据类型:字符型,文本型,数值型,逻辑型和日期型

字符型

VARCHAR VS CHAR

VARCHAR型和CHAR型数据的这个差别是细微的,但是非常重要。他们都是用来储存字符串长度小于255的字符。

假如你向一个长度为四十个字符的VARCHAR型字段中输入数据BIll GAtES。当你以后从这个字段中取出此数据时,你取出的数据其长度为十个字符——字符串Bill Gates的长度。 现在假如你把字符串输入一个长度为四十个字符的CHAR型字段中,那么当你取出数据时,所取出的数据长度将是四十个字符。字符串的后面会被附加多余的空格。

当你建立自己的站点时,你会发现使用VARCHAR型字段要比CHAR型字段方便的多。使用VARCHAR型字段时,你不需要为剪掉你数据中多余的空格而 *** 心。

VARCHAR型字段的另一个突出的好处是它可以比CHAR型字段占用更少的内存和硬盘空间。当你的数据库很大时,这种内存和磁盘空间的节省会变得非常重要

文本型

TEXT

使用文本型数据,你可以存放超过二十亿个字符的字符串。当你需要存储大串的字符时,应该使用文本型数据。

注意文本型数据没有长度,而上一节中所讲的字符型数据是有长度的。一个文本型字段中的数据通常要么为空,要么很大。

当你从HTML fORM的多行文本编辑框(TEXTAREA)中收集数据时,你应该把收集的信息存储于文本型字段中。但是,无论何时,只要你能避免使用文本型字段,你就应该不适用它。文本型字段既大且慢,滥用文本型字段会使服务器速度变慢。文本型字段还会吃掉大量的磁盘空间。

一旦你向文本型字段中输入了任何数据(甚至是空值),就会有2K的空间被自动分配给该数据。除非删除该记录,否则你无法收回这部分存储空间。

数值型

SQL支持许多种不同的数值型数据。你可以存储整数 INT 、小数 NUMERIC、和钱数 MONEY。

INT VS SMALLINT VS TINYINT

他们的区别只是字符长度:

INT型数据的表数范围是从-2,147,483,647到2,147,483,647的整数

SMALLINT 型数据可以存储从-32768到32768的整数

TINYINT 型的字段只能存储从0到255的整数,不能用来储存负数

通常,为了节省空间,应该尽可能的使用最小的整型数据。一个TINYINT型数据只占用一个字节一个INT型数据占用四个字节。这看起来似乎差别不大,但是在比较大的表中,字节数的增长是很快的。另一方面,一旦你已经创建了一个字段,要修改它是很困难的。因此,为安全起见,你应该预测以下,一个字段所需要存储的数值最大有可能是多大,然后选择适当的数据类型。

NUMERIC

为了能对字段所存放的数据有更多的控制,你可以使用NUMERIC型数据来同时表示一个数的整数部分和小数部分。NUMERIC型数据使你能表示非常大的数——比INT型数据要大得多。一个NUMERIC型字段可以存储从-1038到1038范围内的数。NUMERIC型数据还使你能表示有小数部分的数。例如,你可以在NUMERIC型字段中存储小数3.14。

当定义一个NUMERIC型字段时,你需要同时指定整数部分的大小和小数部分的大小。如:MUNERIC(23,0)

一个 NUMERIC型数据的整数部分最大只能有28位,小数部分的位数必须小于或等于整数部分的位数,小数部分可以是零。

MONEY VS SMALLMONEY

你可以使用 INT型或NUMERIC型数据来存储钱数。但是,专门有另外两种数据类型用于此目的。如果你希望你的网点能挣很多钱,你可以使用MONEY型数据。如果你的野心不大,你可以使用SMALLMONEY型数据。MONEY型数据可以存储从-922,337,203,685,477.5808到922,337,203,685,477.5807的钱数。如果你需要存储比这还大的金额,你可以使用NUMERIC型数据。

SMALLMONEY型数据只能存储从-214,748.3648到214,748.3647 的钱数。同样,如果可以的话,你应该用SMALLMONEY型来代替MONEY型数据,以节省空间。

逻辑型

BIT

如果你使用复选框( CHECKBOX)从网页中搜集信息,你可以把此信息存储在BIT型字段中。BIT型字段只能取两个值:0或1。

当心,在你创建好一个表之后,你不能向表中添加 BIT型字段。如果你打算在一个表中包含BIT型字段,你必须在创建表时完成。

日期型

DATETIME VS SMALLDATETIME

一个 DATETIME型的字段可以存储的日期范围是从1753年1月1日第一毫秒到9999年12月31日最后一毫秒。

如果你不需要覆盖这么大范围的日期和时间,你可以使用SMALLDATETIME型数据。它与DATETIME型数据同样使用,只不过它能表示的日期和时间范围比DATETIME型数据小,而且不如DATETIME型数据精确。一个SMALLDATETIME型的字段能够存储从1900年1月1日到2079年6月6日的日期,它只能精确到秒。

DATETIME型字段在你输入日期和时间之前并不包含实际的数据,认识这一点是重要的。

(已修改,请用最新的代码)代码说明:

1级菜单:选择购买的航班号,并显示对应座位状态。

(我只做测试,所以初始化initFlight函数中我只初始了2个航班,需要自己按照我的代码添)

(注意:实际开发软件,链表数据是从数据库中读取的,需要实时同步,如果要多次调用initFlight函数,记得自己写一个释放内存的函数,把所有链表“SINFO和FLINFO”节点都释放掉,释放函数我没写,需要你自己写!!!)

2级菜单:选择购买对应座位号,完成购买,并实时显示购买结果。

位置编号、座位最大排数、舱室类型、折扣等参数均由常量参数空值,需要修改自行改常量。

注意:舱室类型(我默认3个类型头等舱、公务舱、经济舱)对应折扣参数:tDiscount二维数组。如要如要添加新的舱室类型,必须将参数常量TYPESIZE、typeName、types、tDiscount这4个同时修改,具体看代码备注!!

座位票价=基础票价*类型折扣*时段折扣。

因为飞机不让吸烟,所以我没做吸烟区(笑),如果你需要,可以作为类型自行添加!

#include<stdio.h>

#include<stdlib.h>

#include<conio.h>

#include<string.h>

#include<malloc.h>

#include<time.h>

//-----------------------相关参数,想改变,在这里修改!!!!!!!-----------------------------

const float timeDiscount=1//时段折扣,影响所有航班最终价格,默认1

const char cID[5]="ABCD"//位置编号

const int maxRow=20//位置最大排号

//注意:如果修改类型数量,types和tDiscount必须同时修改!!!

#define TYPESIZE 3//类型数量

const char typeName[TYPESIZE][10]={"头等舱","公务舱","经济舱"}

const int types[TYPESIZE][2]={{1,2},{3,4},{5,20}}//排号对应类型。1~2排头等舱,3~4排公务舱,5~20排经济舱

const float tDiscount[TYPESIZE]={1.5,1.3,1}//类型折扣。头等舱1.5倍,公务舱1.3倍,经济舱1倍

//-------------------------------------------------------------------------------

typedef struct seatInfo//座位信息,一条链表对应一个航班信息,链表顺序从第一排左边第一个开始往后A1~D1,A2~D2。。。

{

    char cloID//位置编号A、B、C、D

    int row//位置排号

    int type//座位所属类型:0:头等舱、1:公务舱、2:经济舱,不同类型对应不同的类型折扣tDiscount

    int sell//出售状态,0:未出售;1:已出售

    struct seatInfo *next

}SINFO

typedef struct flightInfo//航班信息

{

    char fid[10]//航班号

    time_t tfTime//起飞时间

    time_t ldTime//降落时间

    char toCity[20]//抵达城市

    float tPrice//基础票价,不同位置具有不同折扣,座位票价=基础票价*类型折扣*时段折扣

    struct flightInfo *next

    struct seatInfo *sHead//对应座位链表的头节点

}FLINFO

void meError(void *p)

SINFO *getSINFO()//获取座位链表

//addFLINFO:添加航班信息链表的节点flinfoHead:头节点(第一次传NULL会自动生成),flinfoTail:尾节点,fNew:要添加的结构信息(成员指针无需赋值)

FLINFO *addFLINFO(FLINFO **ffHead,FLINFO *flinfoTail,FLINFO fNew)//返回尾节点

time_t getTime_tfromStr(char *sTime)//将YYYY-MM-DD hh:mm:ss格式的时间字符串转换成time_t型数值

FLINFO *initFlight()//初始化航班信息,返回航班链表头节点,如果想手动输入,请在这里添加!!!正常软件开发,这一步应该是从数据库读取!

char *getTString(struct tm *tm0)//通过tm获取时间字符串

void showSinfo(FLINFO *flinfo)//显示航班对应座位信息

void printfFlinfo(FLINFO * flinfoHead)

FLINFO *selectFlinfo(FLINFO *flinfoHead,char *fid)//选择航班号,返回节点

void showSinfo(FLINFO *flinfo)//显示航班对应座位信息

SINFO *selectSinfo(FLINFO *flinfo,char *sid)//选择座位,返回节点

int main()

{

    FLINFO *flinfoHead=initFlight(),*ffSelect=NULL

    SINFO *sfSelect=NULL

    char fid[10]={0},sid[10]={10}

    while(1)

    {

        ffSelect=NULL

        sfSelect=NULL

        memset(fid,0,10)

        memset(sid,0,10)

        printfFlinfo(flinfoHead)

        printf("请输入要购买的航班号:")

        scanf("%s",fid)

        ffSelect=selectFlinfo(flinfoHead,fid)

        if(!ffSelect)

        {

            printf("未找到对应航班,按任意键继续-----\n")

            getch()

            system("cls")

            continue

        }

        system("cls")

        printf("航班号:%s 座位信息如下:\n",ffSelect->fid)

        showSinfo(ffSelect)

        printf("请输入要购买的座位编号(输入0返回主菜单):")

        scanf("%s",sid)

        if(!strcmp(sid,"0"))

        {

            system("cls")

            continue

        }

        else

        {

            sfSelect=selectSinfo(ffSelect,sid)

            if(!sfSelect||sfSelect->sell)

            {

                printf("未找到对应座位或该座位已出售,请重新输入!按任意键继续-----\n")

                getch()

                system("cls")

                continue

            }

            printf("购买成功!按任意键继续-----")

            sfSelect->sell=1

            getch()

            system("cls")

        }

    }

    return 0

}

SINFO *selectSinfo(FLINFO *flinfo,char *sid)//选择座位,返回节点

{

    SINFO *sinfoHead=flinfo->sHead

    while(sinfoHead->next)

    {

        if(sinfoHead->next->cloID==sid[0] && sinfoHead->next->row==atoi(sid+1))

            return sinfoHead->next

        sinfoHead=sinfoHead->next

    }

    return NULL

}

void showSinfo(FLINFO *flinfo)//显示航班对应座位信息

{

    SINFO *sinfoHead=flinfo->sHead,*sfp=NULL

    int i,j,k,row=maxRow,clo=strlen(cID)

    char typeStr[10]={0}

    for(i=0i<rowi++)

    {

        //---------读取座位所属舱室------------

        memset(typeStr,0,10)

        for(k=0k<TYPESIZEk++)

            if(i+1>=types[k][0] && i+1<=types[k][1])

                strcpy(typeStr,typeName[k])

        //--------------------------------------

        printf("\n")

        for(j=0j<cloj++)

            printf("------------- ")

        printf("\n")

        sfp=sinfoHead

        for(j=0j<cloj++)

        {

            printf("|    %c%02d    | ",sfp->next->cloID,sfp->next->row)

            sfp=sfp->next

        }

        printf("\n")

        sfp=sinfoHead

        for(j=0j<cloj++)

        {

            printf("|     %c     | ",sfp->next->sell?2:1)

            sfp=sfp->next

        }

        printf("\n")

        sfp=sinfoHead

        for(j=0j<cloj++)

        {

            printf("|%6s:%4.0f| ",typeStr,flinfo->tPrice*tDiscount[sfp->next->type]*timeDiscount)

            sfp=sfp->next

        }

        printf("\n")

        sinfoHead=sfp

    }

    for(j=0i<cloj++)

            printf("------- ")

    printf("\n")

}

FLINFO *selectFlinfo(FLINFO *flinfoHead,char *fid)//选择航班号,返回节点

{

    while(flinfoHead->next)

    {

        if(!strcmp(flinfoHead->next->fid,fid))

            return flinfoHead->next

        flinfoHead=flinfoHead->next

    }

    return NULL

}

void printfFlinfo(FLINFO * flinfoHead)

{

    while(flinfoHead->next)

    {

        printf("目的地:%s,航班号:%s\n----起飞时间:%s,抵达时间:%s\n\n",flinfoHead->next->toCity,flinfoHead->next->fid,getTString(localtime(&flinfoHead->next->tfTime)),getTString(localtime(&flinfoHead->next->ldTime)))

        flinfoHead=flinfoHead->next

    }

}

char *getTString(struct tm *tm0)//通过tm获取时间字符串

{

    char *str=(char *)malloc(sizeof(char)*20),num[5]={0}

    meError(str)

    memset(str,0,20)

    sprintf(num,"%4d",tm0->tm_year+1900)

    strcat(str,num)

    strcat(str,"-")

    memset(num,0,5)

    sprintf(num,"%02d",tm0->tm_mon)

    strcat(str,num)

    strcat(str,"-")

    memset(num,0,5)

    sprintf(num,"%02d",tm0->tm_mday)

    strcat(str,num)

    strcat(str," ")

    memset(num,0,5)

    sprintf(num,"%02d",tm0->tm_hour)

    strcat(str,num)

    strcat(str,":")

    memset(num,0,5)

    sprintf(num,"%02d",tm0->tm_min)

    strcat(str,num)

    strcat(str,":")

    memset(num,0,5)

    sprintf(num,"%02d",tm0->tm_sec)

    strcat(str,num)

    return str

}

time_t getTime_tfromStr(char *sTime)//将YYYY-MM-DD hh:mm:ss格式的时间字符串转换成time_t型数值

{

    time_t rt

    struct tm *tm1=NULL

    rt=time(NULL)

    tm1=localtime(&rt)

    sscanf(sTime,("%4d-%2d-%2d %2d:%2d:%2d"),&tm1->tm_year,&tm1->tm_mon,&tm1->tm_mday,&tm1->tm_hour,&tm1->tm_min,&tm1->tm_sec)

    tm1->tm_year-=1900

    tm1->tm_mon--

    rt=mktime(tm1)

    return rt

}

FLINFO *initFlight()//初始化航班信息,返回航班链表头节点,如果想手动输入,请在这里添加!!!正常软件开发,这一步应该是从数据库读取!

{

    FLINFO *ffHead=NULL,*flinfoTail=NULL,fNew

    //--------添加一个航班信息----需要增加按照我下面调用方式写--------------------------------

    strcpy(fNew.fid,"CI502")

    fNew.tfTime=getTime_tfromStr("2019-02-20 03:30:30")

    fNew.ldTime=getTime_tfromStr("2019-02-20 05:20:30")

    strcpy(fNew.toCity,"台北")

    fNew.tPrice=1000

    fNew.next=NULL

    flinfoTail=addFLINFO(&ffHead,flinfoTail,fNew)

    //--------------------------------------------------------------------------------------------

    strcpy(fNew.fid,"9C8921")

    fNew.tfTime=getTime_tfromStr("2019-02-20 14:30:30")

    fNew.ldTime=getTime_tfromStr("2019-02-20 16:40:30")

    strcpy(fNew.toCity,"香港")

    fNew.tPrice=500

    fNew.next=NULL

    flinfoTail=addFLINFO(&ffHead,flinfoTail,fNew)

    return ffHead

}

FLINFO *addFLINFO(FLINFO **ffHead,FLINFO *flinfoTail,FLINFO fNew)//返回尾节点

//添加航班信息链表的节点flinfoHead:头节点(第一次传NULL会自动生成),flinfoTail:尾节点,fNew:要添加的结构信息(成员指针无需赋值)

{

    FLINFO *flinfoHead=*ffHead

    if(flinfoHead==NULL)

    {

        *ffHead=(FLINFO *)malloc(sizeof(FLINFO))

        flinfoHead=*ffHead

        meError(flinfoHead)

        flinfoHead->next=NULL

    }

    FLINFO *flinfoNew=(FLINFO *)malloc(sizeof(FLINFO))

    meError(flinfoNew)

    flinfoNew->next=NULL

    flinfoNew->fid[0]=0

    strcpy(flinfoNew->fid,fNew.fid)

    flinfoNew->ldTime=fNew.ldTime

    flinfoNew->tfTime=fNew.tfTime

    flinfoNew->toCity[0]=0

    strcpy(flinfoNew->toCity,fNew.toCity)

    flinfoNew->tPrice=fNew.tPrice

    flinfoNew->sHead=getSINFO()

    if(flinfoHead->next==NULL)

        flinfoHead->next=flinfoNew

    else

        flinfoTail->next=flinfoNew

    flinfoTail=flinfoNew

    return flinfoTail

}

SINFO *getSINFO()//获取座位链表

{

    int maxClo=strlen(cID),cnt=maxClo*maxRow,clo=0,row=1,i

    SINFO *sinfoHead=(SINFO *)malloc(sizeof(SINFO)),*sinfoTail=NULL

    meError(sinfoHead)

    sinfoHead->next=NULL

    SINFO *sinfoNew=NULL

    while(cnt--)//按顺序生成对应数量的座位链表

    {

        if(clo==maxClo)

            clo=0,row++

        if(row==maxRow+1)

            row=1

        sinfoNew=(SINFO *)malloc(sizeof(SINFO))

        meError(sinfoNew)

        sinfoNew->cloID=cID[clo]

        sinfoNew->row=row

        for(i=0i<TYPESIZEi++)

            if(row>=types[i][0] && row<=types[i][1])

            {

                sinfoNew->type=i

                break

            }

        sinfoNew->sell=0

        sinfoNew->next=NULL

        if(sinfoHead->next==NULL)

            sinfoHead->next=sinfoNew

        else

            sinfoTail->next=sinfoNew

        sinfoTail=sinfoNew

        clo++

    }

    return sinfoHead

}

void meError(void *p)//内存申请失败

{

    if(p==NULL)

    {

        printf("\n异常:内存申请失败!回车结束程序!\n")

        while(getch()!='\r')

        exit(0)

    }

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9646760.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存