用SQL定义语句创建符合如下条件的数据库: 数据库名为:学生数据库,模式:默认模式 数据文件的物理文件名为:主数据文件Students_data.mdf(逻辑文件同名),日志文件:Students

本文主要是介绍用SQL定义语句创建符合如下条件的数据库: 数据库名为:学生数据库,模式:默认模式 数据文件的物理文件名为:主数据文件Students_data.mdf(逻辑文件同名),日志文件:Students,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、SQL定义语句

1.用SQL定义语句创建符合如下条件的数据库:

数据库名为:学生数据库,模式:默认模式

数据文件的物理文件名为:主数据文件Students_data.mdf(逻辑文件同名),日志文件:Students_log.ldf(逻辑文件同名),存放在D:\Data文件夹下(若D:盘中无此文件夹,请先建立此文件夹,然后再创建数据库。)

2.选用已建立的“学生数据库”,用SQL定义语句创建符合如下条件的表C-1到C-4(注意各种完整性约束)

上述两题,界面方式或命令方式均需要熟练掌握

表C-1 Student表结构

列名

说明

数据类型

约束

Sno

学号

普通编码定长字符串,长度为7

主键

Sname

姓名

普通编码定长字符串,长度为10

 

Ssex

性别

普通编码定长字符串,长度为2

 

Sage

年龄

微整型(tinyint)

 

Sdept

所在系

普通编码不定长字符串,长度为20

 

Sid

身份证号

普通编码定长字符串,长度为10

 

Sdate

入学日期

日期

 

表C-2 Course表结构

列名

说明

数据类型

约束

Cno

课程号

普通编码定长字符串,长度为10

主键

Cname

课程名

普通编码不定长字符串,长度为20

 

Credit

学时数

整型

 

Semester

学分

小整型

 

 

表C-3 SC表结构

列名

说明

数据类型

约束

Sno

学号

普通编码定长字符串,长度为7

主键,引用Student的外键

Cno

课程号

普通编码定长字符串,长度为10

主键,引用Course的外键

Grade

成绩

小整型

 

 

表C-4 Teacher表结构

列名

说明

数据类型

约束

Tno

教师号

普通编码定长字符串,长度为8

 

Tname

教师名

普通编码定长字符串,长度为10

 

Salary

工资

定点小数,小数点前4位,小数点后2位

 

 

3. 写出实现如下功能的SQL语句,并执行所写代码,查看执行结果。

(1) 在Teacher表中添加一个职称列,列名为:Title,类型为nchar(4)。

(2) 将Course表中Credit列的类型改为:tinyint。

(3) 删除Student表中的Sid和Sdate列。

(4) 为Teacher表添加主键约束,其主键为:Tno。

 

表C-1 Student表中的记录,本次上机使用窗口方式录入数据

录入数据时请务必保证数据格式与定义的数据类型一致,否则会报错。

学号

姓名

性别

年龄

系别

身份证号

入学日期

0811101

李勇

21

计算机系

 

 

0811102

刘晨

20

计算机系

 

 

0811103

王敏

20

计算机系

 

 

0811104

张小红

19

计算机系

 

 

0821101

张立

20

信息管理系

 

 

0821102

吴宾

19

信息管理系

 

 

0821103

张海

20

信息管理系

 

 

0831101

钱小平

21

通信工程系

 

 

0831102

王大力

20

通信工程系

 

 

0831103

张姗姗

19

通信工程系

 

 

 

表C-2 Course表中的记录

Cno

Cname

Credit

Semester

C001

高等数学

4

1

C002

大学英语

3

1

C003

大学英语

3

2

C004

计算机文化学

2

2

C005

VB

2

3

C006

数据库基础

4

5

C007

数据结构

4

4

C008

计算机网络

4

4

 

表C-3 SC表中的记录

Sno

Cno

Grade

0811101

C001

96

0811101

C002

80

0811101

C003

84

0811101

C005

62

0811102

C001

92

0811102

C002

90

0811102

C004

84

0821102

C001

76

0821102

C004

86

0821102

C005

73

0821102

C007

NULL

0821103

C001

50

0821103

C004

80

0831101

C001

50

0831101

C004

80

0831102

C007

NULL

0831103

C004

78

0831103

C005

65

0831103

C007

NULL

 

表C-4 Teacher表中的记录

Tno

Tname

Salary

T001

张美霞

5000

T002

王洪林

5500

T003

李丽芬

4800

T004

周良水

6000

T005

吴翔

7000

三.实验结果

Student表

sql语句:

create table Student(Sno char(7) primary key,Sname char(10),Sex char(2),Sage tinyint,Sdept varchar(20),Sid  char(10),Sdate date);

Course表

sql语句:

create table Course(Cno char(10) primary key,Cname varchar(20),Credit int,Semester smallint);

 

Sc

Sql语句:

create table SC(Sno char(7),Cno char(10),Grade smallint,foreign key(Sno) references Student(Sno),foreign key(Cno) references Course(Cno),primary key(Sno,Cno));

Teacher

Sql语句:

create table Teacher(Tno char(8) primary key,Tname char(10),Salary numeric(6,2));

 

写出实现如下功能的SQL语句,并执行所写代码,查看执行结果。

  1. 在Teacher表中添加一个职称列,列名为:Title,类型为nchar(4)
ALTER table Teacher add  Title nchar(4);

  1. 将Course表中Credit列的类型改为:tinyint。  
ALTER table Course alter column Credit tinyint;

 

  1. 删除Student表中的Sid和Sdate列。

 

ALTER table Student drop column Sid,Sdate;

  1. 为Teacher表添加主键约束,其主键为:Tno

 

ALTER table Teacher add unique(Tno);

 

Student表插入数据

INSERT INTO Student(Sno,Sname,Sex,Sage,Sdept) VALUES('0811101','李勇','男',21,'计算机系'),('0811102','刘晨','男',20,'计算机系'),('0811103','王敏','女',20,'计算机系'),('0811104','张小红','女',19,'计算机系'),('0821101','张立','男',20,'信息管理系'),('0821102','吴宾','女',19,'信息管理系'),('0821103','张海','男',20,'信息管理系'),('0831101','钱小平','男',21,'信息管理系'),('0831102','王大力','女',20,'计算机系'),('0831103','张姗姗','男',19,'计算机系');

 

Course表插入数据

INSERT INTO Course(Cno,Cname,Credit,Semester) VALUES('C001','高等数学',4,1),('C002','大学英语',3,1),('C003','大学英语',3,2),('C004','计算机文化学',2,2),('C005','VB',2,3),('C006','数据库基础',4,5),('C007','数据结构',4,4),('C008','计算机网络',4,4);

SC表插入数据

INSERT INTO SC(Sno,Cno,Grade) VALUES('0811101','C001',96),('0811101','C002',80),('0811101','C003',84),('0811101','C005',62),('0811102','C001',92),('0811102','C002',90),('0811102','C004',84),('0821102','C001',76),('0821102','C004',86),('0821102','C005',73),('0821102','C007',NULL),('0821103','C001',50),('0821103','C004',80),('0831101','C001',50),('0831101','C004',80),('0831102','C007',NULL),('0831103','C004',78),('0831103','C005',65),('0831103','C007',NULL); 

 

Teacher表插入数据

INSERT INTO Teacher(Tno,Tname,Salary) VALUES('T001','张美霞',5000),('T002','王洪林',5500),('T003','李丽芬',4800),('T004','周良水',6000),('T005','吴翔',7000);

这篇关于用SQL定义语句创建符合如下条件的数据库: 数据库名为:学生数据库,模式:默认模式 数据文件的物理文件名为:主数据文件Students_data.mdf(逻辑文件同名),日志文件:Students的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/189137

相关文章

MySQL 多表连接操作方法(INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL OUTER JOIN)

《MySQL多表连接操作方法(INNERJOIN、LEFTJOIN、RIGHTJOIN、FULLOUTERJOIN)》多表连接是一种将两个或多个表中的数据组合在一起的SQL操作,通过连接,... 目录一、 什么是多表连接?二、 mysql 支持的连接类型三、 多表连接的语法四、实战示例 数据准备五、连接的性

MySQL中的分组和多表连接详解

《MySQL中的分组和多表连接详解》:本文主要介绍MySQL中的分组和多表连接的相关操作,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录mysql中的分组和多表连接一、MySQL的分组(group javascriptby )二、多表连接(表连接会产生大量的数据垃圾)MySQL中的

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

MySQL 中的 JSON 查询案例详解

《MySQL中的JSON查询案例详解》:本文主要介绍MySQL的JSON查询的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 的 jsON 路径格式基本结构路径组件详解特殊语法元素实际示例简单路径复杂路径简写操作符注意MySQL 的 J

Windows 上如果忘记了 MySQL 密码 重置密码的两种方法

《Windows上如果忘记了MySQL密码重置密码的两种方法》:本文主要介绍Windows上如果忘记了MySQL密码重置密码的两种方法,本文通过两种方法结合实例代码给大家介绍的非常详细,感... 目录方法 1:以跳过权限验证模式启动 mysql 并重置密码方法 2:使用 my.ini 文件的临时配置在 Wi

MySQL重复数据处理的七种高效方法

《MySQL重复数据处理的七种高效方法》你是不是也曾遇到过这样的烦恼:明明系统测试时一切正常,上线后却频频出现重复数据,大批量导数据时,总有那么几条不听话的记录导致整个事务莫名回滚,今天,我就跟大家分... 目录1. 重复数据插入问题分析1.1 问题本质1.2 常见场景图2. 基础解决方案:使用异常捕获3.

SQL中redo log 刷⼊磁盘的常见方法

《SQL中redolog刷⼊磁盘的常见方法》本文主要介绍了SQL中redolog刷⼊磁盘的常见方法,将redolog刷入磁盘的方法确保了数据的持久性和一致性,下面就来具体介绍一下,感兴趣的可以了解... 目录Redo Log 刷入磁盘的方法Redo Log 刷入磁盘的过程代码示例(伪代码)在数据库系统中,r

C 语言中enum枚举的定义和使用小结

《C语言中enum枚举的定义和使用小结》在C语言里,enum(枚举)是一种用户自定义的数据类型,它能够让你创建一组具名的整数常量,下面我会从定义、使用、特性等方面详细介绍enum,感兴趣的朋友一起看... 目录1、引言2、基本定义3、定义枚举变量4、自定义枚举常量的值5、枚举与switch语句结合使用6、枚

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

Nginx location匹配模式与规则详解

《Nginxlocation匹配模式与规则详解》:本文主要介绍Nginxlocation匹配模式与规则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、环境二、匹配模式1. 精准模式2. 前缀模式(不继续匹配正则)3. 前缀模式(继续匹配正则)4. 正则模式(大