SQLserver关于教学楼中教室在某个时间段是否被占用的数据库设计
需求:关于教学楼中教室在周几某个时间段是否被占用的数据库设计
具体代码如下:
-------------------教学楼维度
CREATE TABLE TeacBuild
(
tbID int not null primary key,
tbName varchar(100)
) insert into TeacBuild values(1,'教学楼A')
insert into TeacBuild values(2,'教学楼B')
insert into TeacBuild values(3,'教学楼C')
------------------教室维度
--drop table Room
CREATE TABLE Room
(
seq int identity(1,1),
TID int,
WeekID int,
sno varchar(100),
ID INT NOT NULL,
Rid int not null ,
Rname varchar(20),
tbID int
) ---------------------------------------------周一时间点为8点到16点的
INSERT INTO Room values(1,1,'F',1,101,'101教室',1)
INSERT INTO Room values(1,2,'T',1,101,'101教室',1)
INSERT INTO Room values(1,3,'T',1,101,'101教室',1)
INSERT INTO Room values(1,4,'T',1,101,'101教室',1)
INSERT INTO Room values(1,5,'T',1,101,'101教室',1)
---------------------------------------------周二时间点为8点到16点的
INSERT INTO Room values(2,1,'F',1,101,'101教室',1)
INSERT INTO Room values(2,2,'F',1,101,'101教室',1)
INSERT INTO Room values(2,3,'T',1,101,'101教室',1)
INSERT INTO Room values(2,4,'T',1,101,'101教室',1)
INSERT INTO Room values(2,5,'T',1,101,'101教室',1)
---------------------------------------------周三时间点为8点到16点的
INSERT INTO Room values(3,1,'F',1,101,'101教室',1)
INSERT INTO Room values(3,2,'T',1,101,'101教室',1)
INSERT INTO Room values(3,3,'T',1,101,'101教室',1)
INSERT INTO Room values(3,4,'T',1,101,'101教室',1)
INSERT INTO Room values(3,5,'T',1,101,'101教室',1)
-------------------------------------------------周四时间点为8点到16点的
INSERT INTO Room values(4,1,'F',1,101,'101教室',1)
INSERT INTO Room values(4,2,'F',1,101,'101教室',1)
INSERT INTO Room values(4,3,'T',1,101,'101教室',1)
INSERT INTO Room values(4,4,'T',1,101,'101教室',1)
INSERT INTO Room values(4,5,'T',1,101,'101教室',1)
---------------------------------------------周五时间点为8点到16点的
INSERT INTO Room values(5,1,'F',1,101,'101教室',1)
INSERT INTO Room values(5,2,'T',1,101,'101教室',1)
INSERT INTO Room values(5,3,'T',1,101,'101教室',1)
INSERT INTO Room values(5,4,'T',1,101,'101教室',1)
INSERT INTO Room values(5,5,'T',1,101,'101教室',1) -----------------时间维度
CREATE TABLE DayTime
(
TID int primary key,
Tdesc varchar(20)
) insert into DayTime values(1,'8:00')
insert into DayTime values(2,'10:00')
insert into DayTime values(3,'14:00')
insert into DayTime values(4,'16:00')
-----------------周记天数维度
--drop table WeekTime
CREATE TABLE WeekTime
(
WeekID int primary key,
Weekdesc varchar(20)
) insert into WeekTime values(1,'周一')
insert into WeekTime values(2,'周二')
insert into WeekTime values(3,'周三')
insert into WeekTime values(4,'周四')
insert into WeekTime values(5,'周五') --状态维度表
--drop table STATUE
CREATE TABLE STATUE
(
id int,
Sno varchar,
Staname varchar(10)
)
---F为空 ,T为被占用
insert into STATUE values(1,'F','空')
insert into STATUE values(2,'T','占用') --查询结果
select tb.tbName,rm.Rname,wt.Weekdesc,dt.Tdesc,su.Staname from Room rm --教室表
inner join TeacBuild tb on rm.tbID=tb.tbID --教学楼表
inner join DayTime dt ON dt.TID=rm.TID --时间段表
inner join WeekTime wt on wt.WeekID=rm.WeekID --周表
inner join STATUE su on su.Sno=rm.sno --状态表
-----------------------------锁定一条数据
where 1=1 and
tb.tbID=1 and
rm.ID=1 and
dt.TID=1 and
wt.WeekID=1 and
su.id=1
上述数据查询后的结果为:

这是我自己写的一个简单设计,如果有大神有更好的意见,请指点一下,学习学习
SQLserver关于教学楼中教室在某个时间段是否被占用的数据库设计的更多相关文章
- B-Tree索引在sqlserver和mysql中的应用
在谈论数据库性能优化的时候,通常都会提到“索引”,但很多人其实并没有真正理解索引,也没有搞清楚索引为什么就能加快检索速度,以至于在实践中并不能很好的应用索引.事实上,索引是一种廉价而且十分有效的优化手 ...
- SQLSERVER与C#中数据类型的对应关系
SQLSERVER与C#中数据类型的对应关系 ///<summary> ///数据库中与C#中的数据类型对照 ///</summary> ///<paramname=&q ...
- SQL Server 中如何做到连续时间段的拆分?
今天在工作中遇到了一个很实际的问题,客户在OA接口的员工休假中间表中提供了连续时间段的休假记录,例如: 张三,2018-12-1 ~2018-12-31 ,病假,31天.这样带来的问题是,如果我需要统 ...
- 转 update关联更新在sqlserver和oracle中的实现
sqlserver和oracle中实现update关联更新的语法不同,都可以通过inline view(内嵌视图)来实现,总的来说sqlserver更简单些. 测试例子如下: create table ...
- SQLServer与ASP中DATEDIFF函数区别
一.SQLServer: 格式: DATEDIFF(interval,startdate,enddate) interval参数: 年-yy,yyyy 季度-qq,q 月-mm,m 年中的日-dy,y ...
- SQLServer 事务复制中使用脚本添加某个对象的发布
原文:SQLServer 事务复制中使用脚本添加某个对象的发布 -- use [发布库] --添加表:创建项目并将其添加到发布中 exec sp_addarticle @publication = N ...
- SqlServer 监控发布中未分发的命令数
原文:SqlServer 监控发布中未分发的命令数 对于查看未分发的命令数,我们通常这样查看. 然而当服务器有很多发布时,一个个打开查看就很麻烦 当然,如果想用脚本查看就更方便了,运行下面的语句 -- ...
- SQLSERVER 去除字符串中特殊字符
原文:SQLSERVER 去除字符串中特殊字符 /*========================================================================== ...
- SqlServer判断表中某列是否包含中文,英文,纯数字
原文:SqlServer判断表中某列是否包含中文,英文,纯数字 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog ...
随机推荐
- input[type='submit']input[type='button']button等按钮在低版本的IE下面,去掉黑色边框的问题
今天做一个tabs效果的时候,发现上面的button在低版本下会出现黑色的边框,很难看,于是我整理了下几个去掉黑色边框的办法: 1.在button的外层嵌套一个div,设置button的border: ...
- springmvc(2)--参数绑定
一.以实例来看springmvc各种参数绑定方式 先定义个dto类: public class RestInDto implements Serializable { private static ...
- 配置多个Log4net实例
应用场景: 控制软件工程拆分为多个子项目,在开发阶段希望每个子项目的日志是单独的.同时又希望日志统一集中定义在Tools(Tools为工具类项目,生成Tools.dll)下,而不是分散在各个子项目中. ...
- IOS iphone 4inch上应用没有全屏,上下有黑边(转)
在编写IOS应用程序的过程中,我一直都是使用iPhone Retina(3.5-inch)模拟器测试的,一切显示正常,切图如下: 我在应用开发中,采用的是纯代码实现.公司提供了一部iPhone4s,我 ...
- Macbook之用brew安装Python
1. brew install python 2.If you don't have ~/.bash_profile, add ~/.bash_profile by touch ~/.bash_pro ...
- GetImage
check路径是是否有效,网络访问地址.notfound查找不到,httpstatuscode枚举数较多,根据自己想要的设置就好了. public bool checkValid(string pat ...
- 限额类费用报销单N+1原则
--添加通过自定义档案列表编码及档案编码查询主键 select bd_defdoc.pk_defdoc as defdoc --查询限额类费用类型主键 from bd_defdoc, bd_defdo ...
- 深入浅出ExtJS 第二章 Ext框架基础
2.1 面向对象的基础架构(对象模型) 2.1.1 创建类 >.定义一个类: Ext.define('demo.Demo',{ name:'Lingo', hello:function () { ...
- 反编译工具Reflector ILSpy
最近很长一段时间在为自己技术方便该如何做才会有新的长进而发愁,偶然,顿悟,决定通过反编译工具了解底层代码来进一步提升自己的能力. 于是有了周末宅在家里一天研究反编译工具. 不能浪费了一天的成果,至此, ...
- 关于asp.net MVC 中的TryUpdateModel方法
有比较才会有收货,有需求才会发现更多. 在传统的WebFormk开发工作中,我们常常会存在如下的代码块 //保存 protected void btnSubmit_Click(object sende ...