SQL Server存储过程作业(一)






USE master
GO
--创建数据库Hotel
IF EXISTS (SELECT name FROM sys.databases WHERE name = 'Hotel')
DROP DATABASE Hotel
GO exec sp_configure 'show advanced options',1
reconfigure
go
exec sp_configure 'xp_cmdshell',1
reconfigure
go
use master
go
EXEC xp_cmdshell 'mkdir E:\DB', NO_OUTPUT CREATE DATABASE [Hotel] ON PRIMARY
( NAME = 'Hotel', FILENAME = 'E:\DB\Hotel.mdf' , SIZE = 3072KB , MAXSIZE = UNLIMITED, FILEGROWTH = 1024KB )
LOG ON
( NAME = 'Hotel_log', FILENAME = 'E:\DB\Hotel_log.ldf' , SIZE = 1024KB , MAXSIZE = 20MB , FILEGROWTH = 10%)
GO --创建表
USE Hotel
GO
--创建结账状态表ResideState
IF EXISTS (SELECT * FROM sysobjects WHERE name = 'ResideState')
DROP TABLE ResideState
GO
CREATE TABLE ResideState(
ResideId int IDENTITY(1,1) NOT NULL, --结账状态ID
ResideName varchar(50) NULL --结账状态名称
) ALTER TABLE ResideState
ADD CONSTRAINT PK_ResideState PRIMARY KEY (ResideId)
GO --创建客房类型表RoomType
IF EXISTS (SELECT * FROM sysobjects WHERE name = 'RoomType')
DROP TABLE RoomType
GO
CREATE TABLE RoomType (
TypeID int IDENTITY(1,1) NOT NULL,--客房类型id
TypeName nvarchar(50) NULL, --客房类型名称
TypePrice decimal(18, 2) NULL --客房类型价格
)
GO
ALTER TABLE RoomType
ADD CONSTRAINT PK_RoomType PRIMARY KEY (TypeID)
GO
ALTER TABLE RoomType
ADD CONSTRAINT CK_RoomPrice CHECK(TypePrice >= 0)
GO --创建客房状态表RoomState
IF EXISTS (SELECT * FROM sysobjects WHERE name = 'RoomState')
DROP TABLE RoomState
GO
CREATE TABLE RoomState (
RoomStateID int IDENTITY(1,1) NOT NULL,--房间状态id
RoomStateName nvarchar(20) NULL --房间状态名称
)
GO
ALTER TABLE RoomState
ADD CONSTRAINT PK_RoomState PRIMARY KEY (RoomStateID)
GO --创建客房信息表Room
IF EXISTS (SELECT * FROM sysobjects WHERE name = 'Room')
DROP TABLE Room
GO
CREATE TABLE Room (
RoomID int NOT NULL, --房间id
Description nvarchar(200) NOT NULL, --房间描述
BedNum int NULL, --床位数
GuestNum int NULL, --房客数目
RoomStateID int NOT NULL, --房间状态id
RoomTypeID int NOT NULL --客房类型id
)
GO
ALTER TABLE Room
ADD CONSTRAINT PK_RoomID PRIMARY KEY (RoomID)
GO
ALTER TABLE Room
ADD CONSTRAINT DF_RoomStateID DEFAULT (2) FOR RoomStateID,
CONSTRAINT DF_BedNum DEFAULT (2) FOR BedNum,
CONSTRAINT DF_GuestNum DEFAULT (0) FOR GuestNum,
CONSTRAINT CK_GuestNum CHECK(GuestNum >= 0),
CONSTRAINT FK_RoomStateID FOREIGN KEY(RoomStateID) REFERENCES RoomState(RoomStateID),
CONSTRAINT FK_RoomTypeID FOREIGN KEY(RoomTypeID) REFERENCES RoomType(TypeID)
GO --创建客人信息表GuestRecord
IF EXISTS (SELECT * FROM sysobjects WHERE name = 'GuestRecord')
DROP TABLE GuestRecord
GO
CREATE TABLE GuestRecord (
GuestID int IDENTITY(1,1) NOT NULL,--入住流水ID
IdentityID varchar(50) NOT NULL, --身份证号
GuestName nvarchar(20) NOT NULL, --客人姓名
RoomID int NULL, --客房ID
ResideID int NULL, --入住状态ID
ResideDate datetime NULL, --入住日期
LeaveDate datetime NULL, --结账日期
Deposit decimal(18, 2) NULL, --押金
TotalMoney decimal(18, 2) NULL --总金额
)
GO
ALTER TABLE GuestRecord
ADD CONSTRAINT PK_GuestID PRIMARY KEY(GuestID),
CONSTRAINT DF_ResideID DEFAULT (1) FOR ResideID,
CONSTRAINT CK_LeaveDate CHECK (LeaveDate>=ResideDate),
CONSTRAINT FK_RoomID FOREIGN KEY(RoomID) REFERENCES Room(RoomID),
CONSTRAINT FK_ResideID FOREIGN KEY(ResideID) REFERENCES ResideState(ResideID)
GO --插入数据
--数据插入结账状态表ResideState
INSERT INTO ResideState (ResideName) VALUES('未结帐')
INSERT INTO ResideState (ResideName) VALUES('结帐')
--数据插入客房类型表RoomType
INSERT INTO RoomType (TypeName, TypePrice) VALUES ('标准间',180)
INSERT INTO RoomType (TypeName, TypePrice) VALUES ('单人间',128)
INSERT INTO RoomType (TypeName, TypePrice) VALUES ('三人间',208)
INSERT INTO RoomType (TypeName, TypePrice) VALUES ('单人间',99)
INSERT INTO RoomType (TypeName, TypePrice) VALUES ('总统套房',998)
INSERT INTO RoomType (TypeName, TypePrice) VALUES ('长包房',108)
INSERT INTO RoomType (TypeName, TypePrice) VALUES ('豪华标准间',268)
INSERT INTO RoomType (TypeName, TypePrice) VALUES ('单人套房',368)
INSERT INTO RoomType (TypeName, TypePrice) VALUES ('双人套房',568) --数据插入客房状态表RoomState
INSERT INTO RoomState (RoomStateName) VALUES ('已入住')
INSERT INTO RoomState (RoomStateName) VALUES ('空闲')
INSERT INTO RoomState (RoomStateName) VALUES ('维修') --数据插入客房信息表Room
INSERT INTO Room (RoomID,Description,BedNum,GuestNum,RoomStateID,RoomTypeID) VALUES (1008,'这是双人标准间',2,2,1,1)
INSERT INTO Room (RoomID,Description,BedNum,GuestNum,RoomStateID,RoomTypeID) VALUES (1018,'这是双人标准间',2,0,2,1)
INSERT INTO Room (RoomID,Description,BedNum,GuestNum,RoomStateID,RoomTypeID) VALUES (1028,'这是双人标准间',2,1,1,1)
INSERT INTO Room (RoomID,Description,BedNum,GuestNum,RoomStateID,RoomTypeID) VALUES (1038,'这是双人标准间',2,0,3,1)
INSERT INTO Room (RoomID,Description,BedNum,GuestNum,RoomStateID,RoomTypeID) VALUES (1048,'这是单人间',1,1,1,1)
INSERT INTO Room (RoomID,Description,BedNum,GuestNum,RoomStateID,RoomTypeID) VALUES (1058,'这是单人间',1,1,1,1)
INSERT INTO Room (RoomID,Description,BedNum,GuestNum,RoomStateID,RoomTypeID) VALUES (1068,'这是单人套房',1,1,1,8)
INSERT INTO Room (RoomID,Description,BedNum,GuestNum,RoomStateID,RoomTypeID) VALUES (1078,'这是单人套房',1,0,2,8)
INSERT INTO Room (RoomID,Description,BedNum,GuestNum,RoomStateID,RoomTypeID) VALUES (1088,'这是豪华双人标准间',2,1,1,7)
INSERT INTO Room (RoomID,Description,BedNum,GuestNum,RoomStateID,RoomTypeID) VALUES (1098,'这是豪华双人标准间',2,0,2,7) --数据插入客人信息表GuestRecord
INSERT INTO GuestRecord (IdentityID,GuestName,RoomID,ResideDate,LeaveDate,Deposit,TotalMoney,ResideID)
VALUES ('11010119910101001x','王笑',1008,'2009-9-9 12:30:00','2009-9-10 11:30:02',1000,180,2)
INSERT INTO GuestRecord (IdentityID,GuestName,RoomID,ResideDate,LeaveDate,Deposit,TotalMoney)
VALUES ('','张淼',1008,'2009-9-9 12:30:00','2009-9-10 11:30:02',1000,180)
INSERT INTO GuestRecord (IdentityID,GuestName,RoomID,ResideDate,LeaveDate,Deposit,TotalMoney)
VALUES ('','刘元元',1028,'2009-9-20 22:23:20',null,3000,null)
INSERT INTO GuestRecord (IdentityID,GuestName,RoomID,ResideDate,LeaveDate,Deposit,TotalMoney)
VALUES ('','丁一',1048,'2009-9-29 02:30:40',null,1000,null)
INSERT INTO GuestRecord (IdentityID,GuestName,RoomID,ResideDate,LeaveDate,Deposit,TotalMoney)
VALUES ('','赵玲',1058,'2009-9-18 16:33:13',null,800,null)
INSERT INTO GuestRecord (IdentityID,GuestName,RoomID,ResideDate,LeaveDate,Deposit,TotalMoney)
VALUES ('21201019910710001x','谭坛',1068,'2009-10-3 6:36:09',null,1500,null)
INSERT INTO GuestRecord (IdentityID,GuestName,RoomID,ResideDate,LeaveDate,Deposit,TotalMoney)
VALUES ('','周舟',1088,'2009-10-4 7:50:40',null,5000,null)
SQL Server存储过程作业(一)的更多相关文章
- SQL Server存储过程作业(三)
阶段4:练习——插入入住客人记录 需求说明 使用存储过程将入住客人信息插入客人信息表中,要求: 检查身份证号必须是18个字符组成 押金的默认值为1000元 如果客人记录插入成功,输出客人流水号:否则输 ...
- SQL Server存储过程作业(二)
阶段1:练习——统计某类型客房的入住客人人数 需求说明 使用存储过程统计在指定类型的客房入住客人的总人数 提示: 存储过程的输入参数是指定的客房类型名称 USE Hotel GO --阶段1:查询入住 ...
- 第七篇 SQL Server代理作业活动监视器
本篇文章是SQL Server代理系列的第七篇,详细内容请参考原文 在这一系列的上一篇,你创建并配置SQL Server代理作业.每个作业有一个或多个步骤,可能包含大量的工作流.在这篇文章中,将查看作 ...
- 第二篇 SQL Server代理作业步骤和子系统
本篇文章是SQL Server代理系列的第二篇,详细内容请参考原文. SQL Server代理作业由一系列的一个或多个作业步骤组成.一个作业步骤分配给一个特定的作业子系统(确定作业步骤去完成的工作). ...
- 【译】第七篇 SQL Server代理作业活动监视器
本篇文章是SQL Server代理系列的第七篇,详细内容请参考原文 在这一系列的上一篇,你创建并配置SQL Server代理作业.每个作业有一个或多个步骤,可能包含大量的工作流.在这篇文章中,将查看作 ...
- 【译】第二篇 SQL Server代理作业步骤和子系统
本篇文章是SQL Server代理系列的第二篇,详细内容请参考原文. SQL Server代理作业由一系列的一个或多个作业步骤组成.一个作业步骤分配给一个特定的作业子系统(确定作业步骤去完成的工作). ...
- SQL SERVER 2008复制数据库时发生执行SQL Server代理作业错误
1. 情况说明 在利用SQL SERVER数据库复制向导,能够很方便的将一个数据库从一台服务器复制到另一台服务器上,具体操作步骤也十分简单. 不过在实际操作过程常发生“执行SQL SERVER代理作业 ...
- SQL Server存储过程中使用表值作为输入参数示例
这篇文章主要介绍了SQL Server存储过程中使用表值作为输入参数示例,使用表值参数,可以不必创建临时表或许多参数,即可向 Transact-SQL 语句或例程(如存储过程或函数)发送多行数据,这样 ...
- SQL Server存储过程Return、output参数及使用技巧
SQL Server目前正日益成为WindowNT操作系统上面最为重要的一种数据库管理系统,随着 SQL Server2000的推出,微软的这种数据库服务系统真正地实现了在WindowsNT/2000 ...
随机推荐
- ListView学习(一)
最近了解了LIstView的用法,在听了孙老师的课程后,终于对Adapter有了一定的理解,特作此文记之. ListView在App当中应用相当广泛,比如QQ好友列表.微博等等,都是某种特定的列表,所 ...
- WEB 移动端 CSS3动画性能 优化
很多时候,我们在开发移动端的时候要使自己的网页兼容不同的机型,很多时候会采用CSS3动画,但是很多时候在安卓机下,动画明显会出现卡顿,很难看,那么这里我介绍几个CSS 属性进行硬件加速那么就会得到明显 ...
- LA 4794 状态DP+子集枚举
状态压缩DP,把切割出的面积做状态压缩,统计出某状态下面积和. 设f(x,y,S)为在状态为S下在矩形x,y是否存在可能划分出S包含的面积.若S0是S的子集,对矩形x,y横切中竖切,对竖切若f(x,k ...
- 用Radeon RAMDisk在Windows 10中创建关机或重新启动不消失的内存虚拟盘
之前用ImDisk创建的内存虚拟盘每次关机或重新启动后就会消失,想要开机自己主动创建内存虚拟盘尽管能够用批处理来实现,但还是有点不爽.下载试用了Radeon RAMDisk(Radeon_RAMDis ...
- POJ 2891 Strange Way to Express Integers 中国剩余定理解法
一种不断迭代,求新的求余方程的方法运用中国剩余定理. 总的来说,假设对方程操作.和这个定理的数学思想运用的不多的话.是非常困难的. 參照了这个博客的程序写的: http://scturtle.is-p ...
- OpenCV:Visual Studio 2013 Ultimate中OpenCV 2.4.8 配置
配置环境: 操作系统:Win8.1 64位 IDE平台:Visual Studio 2013 Ultimate 一.准备OpenCV 2.4.8 1.下载:从官网下载 OpenCV2.4.8: ...
- 《解读window核心编程》 之 注冊表
1 注冊表的作用及组织形式 Windows系统使用注冊表来存储系统和应用程序配置数据.非常多系统和应用程序重要的配置的信息都存储在注冊表中. 注冊表是一种以树型结构组织的数据库.树的每个节点称 作键( ...
- 使用U-Boot的NFS(远程/网络用户空间)
前提条件 假设您的主机PC运行的是Ubuntu 14.04.1 LTS或更高版本,并且与您的开发平台在同一个本地网络上;为了简单起见,我们假设网络上也有DHCP服务器.如果使用Juno,请确保使用的是 ...
- 深入浅出时序数据库之预处理篇——批处理和流处理,用户可定制,但目前流行influxdb没有做
时序数据是一个写多读少的场景,对时序数据库以及数据存储方面做了论述,数据查询和聚合运算同样是时序数据库必不可少的功能之一.如何支持在秒级对上亿数据的查询分组聚合运算成为了时序数据库产品必须要面对的挑战 ...
- poj 3498 March of the Penguins(拆点+枚举汇点 最大流)
March of the Penguins Time Limit: 8000MS Memory Limit: 65536K Total Submissions: 4873 Accepted: ...