1、 输入下图的语句, 建立学生表STU.

CREATE TABLE STU
(
SNO NUMERIC() PRIMARY KEY,
SNANE CHAR() NOT NULL,
SSEX CHAR() CHECK (SSEX IN ('男','女')),
SDEPT CHAR()
);

2、输入下图的语句, 建立课程表COU.

CREATE TABLE COU
(
CNO NUMERIC() PRIMARY KEY,
CNANE CHAR() NOT NULL UNIQUE,
CPNO NUMERIC() REFERENCES COU(CNO),
CCREDIT NUMERIC()
);

3、输入下图的语句, 建立选课表STUCOU.

CREATE TABLE STUCOU
(
SNO NUMERIC() REFERENCES STU(SNO),
CNO NUMERIC() REFERENCES COU(CNO),
GRADE NUMERIC(,),
PRIMARY KEY(SNO,CNO)
);

4、 建立供应商表:   ST(Sno,Sname,City)  
     各列数据类型分别为( CHAR(8), CHAR(20), CHAR(20) )
     约束:Sno为主码,Sname唯一,City非空

CREATE TABLE ST
(
SNO CHAR() PRIMARY KEY,
SNAME CHAR() UNIQUE,
CITY CHAR() NOT NULL
)

5、建立零件表:  PT(Pno,Pname,Color)
     各列数据类型分别为( CHAR(8), CHAR(20), CHAR(20) )
     约束:Pno为主码,Pname非空,Color只能是红,黑,蓝

CREATE TABLE PT
(
PNO CHAR() PRIMARY KEY,
PNAME CHAR() NOT NULL,
COLOR CHAR() CHECK (COLOR IN ('红','黑','蓝'))
)

6、建立工程表:  JT(Jno,Jname)        
     各列数据类型分别为( CHAR(8),  CHAR(20) )
     约束:Jno为主码,Jname唯一

CREATE TABLE JT
(
JNO CHAR() PRIMARY KEY,
JNAME CHAR() UNIQUE
)

7、建立供应表:  SPJT(Sno,Pno,Jno,Qty)
     各列数据类型分别为( CHAR(8),CHAR(8),CHAR(8), INT )
     约束:(Sno,Pno,Jno)为主码,   Qty要大于0
      Sno是外码参照ST,Pno是外码参照PT, Jno是外码参照JT

CREATE TABLE SPJT
(
SNO CHAR() REFERENCES ST(SNO),
PNO CHAR() REFERENCES PT(PNO),
JNO CHAR() REFERENCES JT(JNO),
QTY INT CHECK (QTY>),
PRIMARY KEY (SNO,PNO,JNO)
)

8、查看批处理文件CREATE_TABLES.SQL中对学生三个表的定义(不用执行),  写出以下引起完整性约束报错的操作语句,记录显示的出错信息,并解释操作违反了何种数据完整性?

(1) 执行下面语句:

insert INTO STUDENT(sname, ssex,sage,sdept) values( '刘楠','男',,'CS');

1).出错信息

2). 对出错信息的解释( 出错原因, 违反了哪种完整性等):

出错原因,主属性为空置,违反了实体完整性。

(2)修改student中数据, 将95001的学号改为99001

1).语句:

UPDATE STUDENT
SET SNO=''
WHERE SNO=''

2).出错信息(将出错信息复制至此):

3).对出错信息的解释( 出错原因, 违反了哪种完整性等)::

修改student表中一个元组sno属性,造成修改后sc中的sno在student找不到一个元组,其sno属性值与之相等。

违反了参照完整性。

(3)删除student中95002的元组

1).语句:

DELETE
FROM STUDENT
WHERE SNO=''

2).出错信息:

3).解释:

从student表中删除一个元组的sno属性,造成sc表中的某些元组的sno属性值在表student中找不到一个元组,其sno值与之对应。

违反了参照完整性。

(4)试图在student中插入下面的元组:

( 99001,'赵冬','M',19,'CS')

1).语句:

INSERT INTO STUDENT(SNO,SNAME,SSEX,SAGE,SDEPT)
values( '','赵冬','M',,'CS');

2).出错信息:

3).解释:

在创建student时限制ssex只能是‘男’,或者‘女’。

违反了用户自定义完整性。

(5)删除course中2号课的元组

1).语句:

DELETE
FROM COURSE
WHERE CNO=

2).出错信息:

3).解释:

从COURSE表中删除一个元组的CNO属性,造成SC表中的某些元组的CNO属性值在表COURSE中找不到一个元组,其CNO值与之对应。违反了参照完整性。

(6)  在SC中插入一条学号为99990,选1号课,成绩90的学生选课信息

1).语句:

INSERT INTO SC(SNO,CNO,GRADE)
VALUES('',,);

2).出错信息:

3).解释:

SC表中增加一个元组,该元组的SNO属性值在表STUDENT中找不到一个元组,其SNO属性值与之对应。

数据库——SQL-SERVER练习(4) 建表及数据完整性的更多相关文章

  1. SQL SERVER 生成MYSQL建表脚本

    /****** Object: StoredProcedure [dbo].[GET_TableScript_MYSQL] Script Date: 06/15/2012 13:05:14 ***** ...

  2. SQL SERVER 生成ORACLE建表脚本

    /****** Object: StoredProcedure [dbo].[GET_TableScript_ORACLE] Script Date: 06/15/2012 13:07:16 **** ...

  3. 数据库SQL server 删除一张表中的重复记录

    --建立一张表 create table cat( catId int, catName varchar(40) ) --将下边的插入语句,多执行几次. insert into catvalues(1 ...

  4. Sql Server系列:数据表操作

    表是用来存储数据和操作数据的逻辑结构,用来组织和存储数据,关系数据库中的所有数据都表现为表的形式,数据表由行和列组成.SQL Server中的数据表分为临时表和永久表,临时表存储在tempdb系统数据 ...

  5. 查看SQL Server被锁的表以及如何解锁

    锁定数据库的一个表的区别 SELECT * FROM table WITH (HOLDLOCK) 其他事务可以读取表,但不能更新删除 SELECT * FROM table WITH (TABLOCK ...

  6. 把sql server 2000的用户表的所有者改成dbo

    怎么样把sql server 2000的用户表的所有者,改成dbo,而不是用户名. 推荐使用下面介绍的第二种方法,执行以下查询便可以了.sp_configure 'allow updates','1' ...

  7. SQL Server 2008 无法保存表的更改

    MS SQL Server 2008 在建完表后,如果要重新设计表,如修改字段长度,就会提示:“当用户在在SQL Server 2008企业管理器中更改表结构时,必须要先删除原来的表,然后重新创建新表 ...

  8. MS SQL SERVER 中的系统表

    MS SQL SERVER 中的系统表 序号 名称 说明 备注 1 syscolumns 每个表和视图中的每列在表中占一行,存储过程中的每个参数在表中也占一行.   2 syscomments 包含每 ...

  9. SQL Server 2014内存优化表的使用场景

    SQL Server 2014内存优化表的使用场景 最近一个朋友找到走起君,咨询走起君内存优化表如何做高可用的问题 大家知道,内存优化表是从SQL Server 2014开始引入,可能大家对内存优化表 ...

  10. 数据库管理工具神器-DataGrip,可同时管理多个主流数据库[SQL Server,MySQL,Oracle等]连接

    前言 DataGrip:Jet Brains出品的一款数据库管理工具(没错,是Jet Brains出品,必属精品).DataGrip整合集成了当前主流数据库(如:SQL Server, MySQL, ...

随机推荐

  1. H5移动端开发遇见的东西

    常见的有viewport.强制浏览器全屏.IOS的Web APP模式.可点击元素出现阴影 本文主要讲一些其他的或者实用的优化手段. 1. 弹出数字键盘 <!-- 有"#" & ...

  2. C++入门到理解阶段二核心篇(1)——c++面向对象概述、内存分析、引用

    1.c++内存分区模型 c++程序在运行的过程中,内存会被划分为以下四个分区 代码区:程序的所有程序的二进制代码,包括注释会被放到此区 全局区:存放静态变量.全局变量.常量(字符串常量和const修饰 ...

  3. mysql分布式

    一,复制,对数据进行备份,实现搞可用,提高吞吐量,实现高性能. 1,主从架构 2,多主架构 3,主主从从 4,主备 (实际用得多) 二,分片/分库分表 () 1,垂直拆分 1,垂直分表 2,垂直分库 ...

  4. MyBatis的事物管理和缓存

    MyBatis的事物 事物的概念 在Java语言数据库框架中,数据库的事务管理都是非常重要的. 每个业务逻辑都是由一系列数据库访问完成的,这些访问可能修改多条数据记录,这一系列修改应该是一个整体,绝对 ...

  5. Python:多态、协议和鸭子类型

    多态 问起面向对象的三大特性,几乎每个人都能对答如流:封装.继承.多态.今天我们就要来说一说 Python 中的多态. 所谓多态:就是指一个类实例的相同方法在不同情形有不同表现形式.多态机制使具有不同 ...

  6. Android Studio如何配置CURL指令一键打包apk上传至蒲公英

    Android Studio如何配置CURL指令一键打包apk上传至蒲公英 第一步:在所需要打包的模块build.gradle文件中加入如下代码: android{ buildTypes { //配置 ...

  7. Python—包管理工具与上传工具

    https://blog.csdn.net/libbyandhelen/article/details/78808959 https://www.cnblogs.com/nineep/p/947529 ...

  8. c/c++概述

    c/c++的学习分为两个部分 一.语言标准 语言标准定义了功能特性和标准库两部分. 功能特性由编译器负责具体实现,比如linux下gcc,windows下Visual Studio 标准库实现依赖于具 ...

  9. Educational Codeforces Round 71 (Rated for Div. 2)

    传送门 A.There Are Two Types Of Burgers 签到. B.Square Filling 签到 C.Gas Pipeline 每个位置只有"高.低"两种状 ...

  10. acwing 167. 木棒

    乔治拿来一组等长的木棒,将它们随机地砍断,使得每一节木棍的长度都不超过50个长度单位. 然后他又想把这些木棍恢复到为裁截前的状态,但忘记了初始时有多少木棒以及木棒的初始长度. 请你设计一个程序,帮助乔 ...