1、创建一个数据库StudentManage, 初始化大小10M,不足以1M每次增长
create database StudentManage
on
(
name = 'StudentManage_data',
filename = 'D:\StudentManage_data.mdf',
size = 10mb,
maxsize = 100mb,
filegrowth = 15%
)
log on
(
name = 'StudentManage_log',
filename = 'D:\StudentManage_log.ldf',
size = 2mb,
filegrowth = 1mb
)
2、其中表结构包括
学生信息表:StudentInfo
( 学生ID(主键),
所在班级ID(外键约束),
学生姓名(非空约束),
性别(检查约束(男,女)),
年龄(检查约束(6-30)),
身份证号(检查约束),
家庭地址(默认值‘地址不详’))
create table StudentInfo
(
StuId varchar(10) primary key,
ClassId varchar(8) foreign key references ClassInfo(ClassId),
StuName varchar(6) not null,
Sex varchar(4) default '男' check(Sex='男'or Sex='女'),
Age smallint check(Age>0 and Age<36),
IdNum char(18) check(IdNum like '[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9,X]'),
StuAddress nvarchar(50) default '地址不详',
)
教师信息表:TeacherInfo
(教师ID(主键),
教师姓名(非空约束),
性别(检查约束(男,女)),
年龄(检查约束(25-60)),
身份证号(检查约束),
教学方向
家庭地址(默认值‘地址不详’))
create table TeacherInfo
(
TecId varchar(10) primary key,
TecName varchar(8) not null,
Sex varchar(4) default '男' check(Sex='男' or Sex='女'),
Age smallint check(Age>25 and Age<60),
IdNum char(18) check(IdNum like '[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9,X]'),
TecWhat nvarchar(8) not null,
TecAddress nvarchar(50) default '地址不详',
)
班级信息表:ClassInfo
(班级ID(主键),
班级名称(非空约束),
班级人数(15-60),
入校时间,
毕业时间
)
use StudentManage
create table ClassInfo
(
ClassId varchar(8) primary key,
ClassName varchar(8) not null,
CstuNum int,
InDate date,
GraduDate date
)
课程信息表:CourseInfo
(课程ID(主键),
课程名称(非空约束),
)
create table CourseInfo
(
CourId varchar(8) primary key,
CourName varchar(8) not null
)
考分信息表:Scores
(ID(标识列,(1, 1)),
学生ID(外键约束),
教师ID(外键约束),
考试批次,--第一次考还是补考?
分数(0-100)
)
create table ScoresInfo
(
ScoreId int primary key identity(1,1),
StuId varchar(10) foreign key references StudentInfo(StuId),
TecId varchar(10) foreign key references TeacherInfo(TecId),
PiCi varchar(8),
Score smallint check(Score>=0 and Score <=100)
)
3、以上的每个表至少加入3条以上的记录
use StudentManage
--向班级表插入三条数据
insert into ClassInfo
values('101','计算机',50,'2010-09-09','2014-10-10')
insert into ClassInfo
values('102','嵌入式',50,'2010-09-09','2014-10-10')
insert into ClassInfo
values('103','网络安全',50,'2010-09-09','2014-10-10')
--向学生信息表里插入数据
insert into StudentInfo
values('144712190','101','武索普','男',18,'411481199012102908',default)
insert into StudentInfo
values('144712221','102','路飞','男',18,'211481199012102593',default)
insert into StudentInfo
values('144712321','103','罗宾','女',18,'511481199012102908',default)
--向教师信息表里插入数据
insert into TeacherInfo
values('541001','白胡子','男',50,'123456789098765432','震震大地',default)
insert into TeacherInfo
values('541002','罗利','男',50,'323456789098765432','催眠掌',default)
insert into TeacherInfo
values('541003','帝喾克','女',26,'523456789098765432','媚眼',default)
--向课程信息表里插入数据
insert into CourseInfo
values('101','气武镜')
insert into CourseInfo
values('102','玄武镜')
insert into CourseInfo
values('103','灵武镜')
insert into CourseInfo
values('104','天武镜')
--向成绩表里插入数据
insert into ScoresInfo
values('144712190','541001','第一批',100)
insert into ScoresInfo
values('144712221','541002','第一批',100)
insert into ScoresInfo
values('144712321','541003','第一批',100)
- 常用sql语句总结(二)(更新数据,序列,创建数据表,约束,注释)
常用sql语句总结(二)(更新数据,序列,创建数据表,约束,注释) 一. 增 INSERT INTO 数据表(字段,字段,-) VALUES(值,值-); INSERT INTO emp(empno, ...
- sql语句小记录
测试过程中,需要去数据库中查询一些结果,比如验证码 常用的是查询 更新比较少用 删除一般不用 sql查询语句的嵌套用法,比较实用 比如in的用法:第一种:查询多个值时 SELECT "栏位名 ...
- SQL语句小总结
无论是面试过程中,还是未来工作中,SQL都是一定会考到和用到的.所以,在此对之前看过的一些SQL知识点进行一下总结和记录,算是起到一个笔记本的作用.没有深入学习过SQL的和对SQL印象不太深的朋友可以 ...
- SQL语句汇总(二)——数据修改、数据查询
SQL语句第二篇,不说废话直接开始吧. 首先创建一张表如下,创建表的方法在上篇介绍过了,这里就不再赘述. 添加新数据: INSERT INTO <表名> (<列名列表>) VA ...
- SQL语句学习(二)
为一张表添加外键: 这里我们希望再建一张订单的表为t_order,包含order_id,customer_id和price: ) NOT NULL auto_increment PRIMARY KEY ...
- mysql使用基础 sql语句与数据完整性(二)
二.DML:Data Manipulation Language 数据操作语言 作用:操作表中的数据的. 关键:INSERT UPDATE DELETE 注意:日期或字符串.字符要使用单引号引起来. ...
- SQL 语句优化—— (二) 索引的利用
索引是与表或视图关联的磁盘上结构,可以加快从表或视图中检索行的速度.索引包含由表或视图中的一列或多列生成的键.与书中的索引一样,数据库中的索引使您可以快速找到表或索引视图中的特定信息.索引包含从表或视 ...
- sql语句小练习一
create database aaa go use aaa go create table student( sno varchar(3), sname varchar(4) not null ...
- SQL语句(十二)分组查询
(十二)分组查询 将数据表中的数据按某种条件分成组,按组显示统计信息 查询各班学生的最大年龄.最小年龄.平均年龄和人数 分组 SELECT <字段名表1> FROM <表名> ...
随机推荐
- PLSQL_Oracle Table Lock表级锁的处理(案例)
20150506 Created By BaoXinjian
- 2016 Multi-University Training Contest 5 World is Exploding
转载自:http://blog.csdn.net/queuelovestack/article/details/52096337 [题意]给你一个序列A,选出四个下标不同的元素,下标记为a,b,c,d ...
- vim 学习日志(3):跳到行尾、行首、文件尾、文件首、加密
vi操作: 1.跳到文本的最后一行:按“G”,即“shift+g” 2.跳到最后一行的最后一个字符 : 先重复1的操作即按“G”,之后按“$”键,即“shift+4”. 3.跳到第一行的第一个字符:先 ...
- git同步开发更新至项目目录(转载)
From:http://toroid.org/ams/git-website-howto 本地版本库中存放开发的项目代码.以下内容介绍如何将本地版本库修改通过执行“git push web”命令同步到 ...
- vi命令的使用
<转:http://linux.vbird.org/linux_basic/0310vi.php> 基本上 vi 共分为三种模式,分别是『一般模式』.『编辑模式』与『指令列命令模式』. 圖 ...
- python 装饰器和 functools 模块
转自:http://blog.jkey.lu/2013/03/15/python-decorator-and-functools-module/ 什么是装饰器? 在 python 语言里第一次看到装饰 ...
- 用HTML代码加载Unity内容(unity频道:http://unity3d.9ria.com/)
Unity内容在浏览器通过Unity网络播放器插件加载.HTML代码与这个插件通常不直接通信,而是通过UnityObject的脚本帮助.其主要任务是Unity的内容嵌入一个非常简单的任务,通过从各种浏 ...
- Oracle Profile 使用详解--zhuanzai
一.目的: Oracle系统中的profile可以用来对用户所能使用的数据库资源进行限制,使用Create Profile命令创建一个Profile,用它来实现对数据库资源的限制使用,如果把该prof ...
- sqlserver添加用户的时候出现 错误18456
1.用本机默认的window身份验证登录 2.登录成功后,在数据库->安全性->登录名->右键属性->如图选择“新建登录名” 3.在如图所示的登录名中,输入将要新建的登录用户, ...
- junit组合模式应用
组合模式 定义: 将对象组合成树形结构以表示“部分-整体”的层次结构.Composite模式使得用户对单个对象和组合对象的使用具有一致性 构成: Component:这是一个抽象角色,它给参加组合的对 ...