SQL语言基础及数据定义功能.ppt_第1页
SQL语言基础及数据定义功能.ppt_第2页
SQL语言基础及数据定义功能.ppt_第3页
SQL语言基础及数据定义功能.ppt_第4页
SQL语言基础及数据定义功能.ppt_第5页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、1,SQL 语言基础及数据定义功能,SQL语言概述,SQL的数据类型,数据定义,提纲,要求:了解SQL语言的特点;掌握SQL语言的功能;了解SQL的数据类型;掌握数据定义功能;掌握数据完整性的概念及定义方法,2,1.SQL语言的发展,一、SQL语言概述,SQL(Structured Query Language) 结构化查询语言,是关系数据库的标准语言。 SQL是一个通用的、功能极强的关系数据库语言。,标准 大致页数 发布日期 SQL/86 1986.10 SQL/89(FIPS 127-1) 120页 1989年 SQL/92 622页 1992年 SQL99 1700页 1999年 SQL

2、2003 2003年,现状:大部分DBMS产品都支持SQL,成为操作数据库的标准语言。 有方言,支持程度不同,3,综合统一,2.SQL语言的特点及功能概述,集数据定义语言(DDL),数据操纵语言(DML),数据控制语言(DCL)功能于一体。 可以独立完成数据库生命周期中的全部活动: 定义关系模式,插入数据,建立数据库; 对数据库中的数据进行查询和更新; 数据库重构和维护; 数据库安全性、完整性控制等 用户数据库投入运行后,可根据需要随时逐步修改模式,不影响数据的运行。 数据操作符统一,高度非过程化,非关系数据模型的数据操纵语言“面向过程”,必须制定存取路径。 SQL只要提出“做什么”,无须了解

3、存取路径。 存取路径的选择以及SQL的操作过程由系统自动完成。,一、SQL语言概述,4,面向集合的操作方式,2.SQL语言的特点及功能概述,非关系数据模型采用面向记录的操作方式,操作对象是一条记录 SQL采用集合操作方式:操作对象、查找结果可以是元组的集合;一次插入、删除、更新操作的对象可以是元组的集合,以同一种语法结构提供多种使用方式,SQL是独立的语言:能够独立地用于联机交互的使用方式 SQL又是嵌入式语言:SQL能够嵌入到高级语言(例如C,C+,Java)程序中,供设计程序时使用,以同一种语法语言简洁,易学易用,一、SQL语言概述,SQL功能极强,完成核心功能只用了9个动词:,5,SQL

4、支持关系数据库三级模式结构,3.SQL的基本概念,一、SQL语言概述,6,3.SQL的基本概念,基本表:本身独立存在的表。SQL中一个关系就对应一个基本表;一个(或多个)基本表对应一个存储文件;一个表可以带若干索引。 存储文件:逻辑结构组成了关系数据库的内模式;物理结构是任意的,对用户透明。 视图:从一个或几个基本表导出的表。数据库中只存放视图的定义而不存放视图对应的数据;视图是一个虚表;用户可以在视图上再定义视图。,一、SQL语言概述,7,二、SQL的数据类型,SQL的数据类型,SQL中域的概念用数据类型来实现 定义表的属性时 需要指明其数据类型及长度:选用哪种数据类型、取值范围、要做哪些运

5、算等,日期,包含年、月、日,格式为YYYY-MM-DD HH:MM:SS,DATETIME,浮点数,精度至少为n位数字,FLOAT(n),取决于机器精度的浮点数,REAL,由p位数字(不包括符号、小数点)组成,小数后面有q.0qp15,decimal(p,q),短整数,SMALLINT,长整数(也可以写作INTEGER),INT,最大长度为n的变长字符串,VARCHAR(n),长度为n的定长字符串,CHAR(n),含义,数据类型,SQL Server 支持的数据类型,8,三、数据定义,SQL的数据定义功能: 模式定义、表定义、视图和索引的定义,SQL的数据定义语句,定义基本表,基本表:本身独立

6、存在的表。SQL中一个关系就对应一个基本表;一个(或多个)基本表对应一个存储文件;一个表可以带若干索引。,1.基本表的定义、删除,DDL,9,定义基本表,CREATE TABLE ( , , ); 如果完整性约束条件涉及到该表的多个属性列,则必须定义在表级上,否则既可以定义在列级也可以定义在表级。,1.基本表的定义、删除,例 1 建立“学生”表Student,学号是主码,姓名取值唯一。 CREATE TABLE Student (Sno CHAR(9) PRIMARY KEY, /* 列级完整性约束条件*/ Sname CHAR(20) UNIQUE, /* Sname取唯一值*/ Ssex

7、CHAR(2), Sage SMALLINT, Sdept CHAR(20) );,三、数据定义,10,附:使用企业管理器创建惟一约束。操作步骤如下: 打开企业管理器,选择要设置惟一约束的表,这里选择mytable表,并单击鼠标右键选择“设计表”命令。 在设计表窗口中单击快捷工具栏中的 按钮,打开“属性”对话框。 在“属性”对话框中选择“索引/键”选项卡,然后单击“新建”按钮,在“列名”下拉列表中选择要创建为惟一约束的列名称,并选中“创建 UNIQUE”复选框和“约束”单选按钮。最后在“索引名”文本框中输入惟一约束名称即可。 关闭“属性”对话框,并单击工具栏中的 按钮保存设置,定义基本表,1.

8、基本表的定义、删除,三、数据定义,11,定义基本表,1.基本表的定义、删除,例2 建立一个“课程”表Course CREATE TABLE Course ( Cno CHAR(4) PRIMARY KEY, Cname CHAR(40), Cpno CHAR(4) , Ccredit SMALLINT, FOREIGN KEY (Cpno) REFERENCES Course(Cno) );,三、数据定义,12,定义基本表,1.基本表的定义、删除,例3 建立一个“学生选课”表SC CREATE TABLE SC (Sno CHAR(9), Cno CHAR(4), Grade SMALLINT

9、, PRIMARY KEY (Sno,Cno), /* 主码由两个属性构成,必须作为表级完整性进行定义*/ FOREIGN KEY (Sno) REFERENCES Student(Sno), /* 表级完整性约束条件,Sno是外码,被参照表是Student */ FOREIGN KEY (Cno) REFERENCES Course(Cno) /* 表级完整性约束条件, Cno是外码,被参照表是Course*/ );,三、数据定义,13,删除基本表,1.基本表的定义、删除,DROP TABLE ; 删除表是有限制的。欲删除的基本表不能被其他表的约束所引用,如果存在依赖该表的对象,则此表不能被

10、删除,例4 删除Student表 DROP TABLE Student ;,例5 若表上建有视图不能删除,DROP TABLE Student; -ERROR: cannot drop table Student because other objects depend on it,CREATE VIEW IS_Student AS SELECT Sno,Sname,Sage FROM Student WHERE Sdept=IS;,三、数据定义,14,修改基本表,2.修改基本表,ALTER TABLE ADD 完整性约束 DROP ALTER COLUMN ADD 完整性约束定义 ;,例6向

11、Student表增加“入学时间”列,其数据类型为日期型。 ALTER TABLE Student ADD S_entrance DATE; 不论基本表中原来是否已有数据,新增加的列一律为空值。 例7将年龄的数据类型由字符型(假设原来的数据类型是字符型)改为整数。 ALTER TABLE Student ALTER COLUMN Sage INT; 例8增加课程名称必须取唯一值的约束条件。 ALTER TABLE Course ADD UNIQUE(Cname);,三、数据定义,15,3.数据完整性,完整性约束条件的作用对象,列级约束 元组完整性约束 关系约束,约束定义, 列取值非空约束 NOT

12、 NULL 例:sname char(10) NOT NULL 表主码约束:在定义列时定义主码(仅用于单列主码) 列定义 PRIMARY KEY 例: SNO char(7) PRIMARY KEY 在定义完列时定义主码(用于单列或多列主码) PRIMARY KEY () 例: PRIMARY KEY(SNO) PRIMARY KEY(SNO,CNO),三、数据定义,16,外码引用约束:指明本表外码列引用的表及表中的主码列。 FOREIGN KEY () REFERENCES () 例:FOREIGN KEY (sno)REFERENCES 学生表(sno) 默认值约束 格式:DEFAULT

13、默认值 例:定义系的默认值为“计算机系”。 DEFAULT 计算机系 CHECK约束 格式:CHECK (约束表达式) 例:定义成绩大于等于0。 CHECK ( grade = 0 ),3.数据完整性,约束定义,三、数据定义,17,UNIQUE约束 在列级约束定义(仅用于单列约束) 列定义 UNIQUE 例: SNAME char(7) UNIQUE 在表级约束定义(用于单列或多列组合约束) UNIQUE () 例: UNIQUE (SNO,CNO) CREATE TABLE Student ( Sno char(7) PRIMARY KEY, Sname char(10) NOT NULL,

14、 Ssex char(2) CHECK(Ssex=男OR Ssex=女), Sage tinyint CHECK(Sage=15 AND Sage=45), Sdept char (20) DEFAULT 计算机系 ),3.数据完整性,约束定义,三、数据定义,练习:将student表增加入学时间列,并设定默认值; 将性别列加上取值男或女的约束,并设定为非空。 将course表中的Cname设定为唯一的。,18,1. 学生关系模式为R1(学号,姓名,性别,班号),其中学号为主键;班级关系模式为R2(班号,专业,教室,),其中班号为主键;则学生关系模式中的外键应该设为()。 学号 B.姓名 C.性别 D.班号 2. 分别写出DDL、DML、DB、DBA、DBMS的汉语名称。 3. 关系Ra,b,c中主键码为a,b,则合适的SQL语句为() A.create table test1(a char(10) primary key,b char(10),c char(10); B. create table test1(a char(10),b char(10) primary key,c char(10); C. create table test1(a char(10),b char(10),c

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论