第三讲2 SQL 语言基础及数据定义功能

上传人:小*** 文档编号:243136802 上传时间:2024-09-16 格式:PPT 页数:18 大小:155KB
返回 下载 相关 举报
第三讲2 SQL 语言基础及数据定义功能_第1页
第1页 / 共18页
第三讲2 SQL 语言基础及数据定义功能_第2页
第2页 / 共18页
第三讲2 SQL 语言基础及数据定义功能_第3页
第3页 / 共18页
点击查看更多>>
资源描述
单击此处编辑母版标题样式,单击此处编辑母版文本样式,第二级,第三级,第四级,第五级,*,*,*,SQL,语言基础及数据定义功能,SQL,语言概述,SQL,的数据类型,数据定义,提纲,要求:,了解,SQL,语言的特点;掌握,SQL,语言的功能,;了解,SQL,的数据类型;掌握,数据定义功能,;掌握数据完整性的概念及,定义方法,1,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,年,SQL2003 2003,年,现状,:,大部分,DBMS,产品都支持,SQL,,成为操作数据库的,标准语言。,有方言,支持程度不同,2,综合统一,2,.,SQL,语言的特点及功能概述,集数据定义语言(,DDL,),数据操纵语言(,DML,),数据控制语言(,DCL,)功能于一体。,可以独立完成数据库生命周期中的全部活动: 定义关系模式,插入数据,建立数据库; 对数据库中的数据进行查询和更新; 数据库重构和维护; 数据库安全性、完整性控制等,用户数据库投入运行后,可根据需要随时逐步修改模式,不影响数据的运行。,数据操作符统一,高度非过程化,非关系数据模型的数据操纵语言“面向过程”,必须制定存取路径。,SQL,只要提出“做什么”,无须了解存取路径。,存取路径的选择以及,SQL,的操作过程由系统自动完成。,一、,SQL,语言概述,3,面向集合的操作方式,2,.,SQL,语言的特点及功能概述,非关系数据模型采用面向记录的操作方式,操作对象是一条记录,SQL,采用集合操作方式:操作对象、查找结果可以是元组的集合;一次插入、删除、更新操作的对象可以是元组的集合,以同一种语法结构提供多种使用方式,SQL,是独立的语言:能够独立地用于联机交互的使用方式,SQL,又是嵌入式语言:,SQL,能够嵌入到高级语言(例如,C,,,C+,,,Java,)程序中,供设计程序时使用,以同一种语法语言简洁,易学易用,一、,SQL,语言概述,SQL,功能极强,完成核心功能只用了,9,个动词:,4,SQL,支持关系数据库三级模式结构,3,.,SQL,的基本概念,SQL,视图,2,视图,1,基本表,2,基本表,1,基本表,3,基本表,4,存储文件,2,存储文件,1,外模式,模 式,内模式,一、,SQL,语言概述,5,3,.,SQL,的基本概念,基本表:本身独立存在的表。,SQL,中一个关系就对应一个基本表;一个,(,或多个,),基本表对应一个存储文件;一个表可以带若干索引。,存储文件:逻辑结构组成了关系数据库的内模式;物理结构是任意的,对用户透明。,视图:从一个或几个基本表导出的表。数据库中只存放视图的定义而不存放视图对应的数据;视图是一个虚表;用户可以在视图上再定义视图。,一、,SQL,语言概述,6,二、,SQL,的数据类型,SQL,的数据类型,SQL,中,域,的概念用,数据类型,来实现,定义表的属性时 需要指明其数据类型及长度:选用哪种数据类型、取值范围、要做哪些运算等,日期,包含年、月、日,格式为,YYYY-MM-DD,HH:MM:SS,DATETIME,浮点数,精度至少为,n,位数字,FLOAT(n,),取决于机器精度的浮点数,REAL,由,p,位数字(不包括符号、小数点)组成,小数后面有,q.,0,qp15,decimal(p,,,q),短整数,SMALLINT,长整数(也可以写作,INTEGER,),INT,最大长度为,n,的变长字符串,VARCHAR(n,),长度为,n,的定长字符串,CHAR(n,),含义,数据类型,SQL Server,支持的数据类型,7,三、数据定义,SQL,的数据定义功能,:,模式定义、表定义、视图和索引的定义,SQL,的数据定义语句,定义基本表,基本表:本身独立存在的表。,SQL,中一个关系就对应一个基本表;一个,(,或多个,),基本表对应一个存储文件;一个表可以带若干索引。,1,.,基本表的定义、删除,DDL,8,定义基本表,CREATE TABLE ,(, ,,, ,,, ,),;,如果,完整性约束条件,涉及到该表的多个属性列,则必须定义在表级上,否则既可以定义在列级也可以定义在表级。,1,.,基本表的定义、删除,例,1,建立,“学生”表,Student,,学号是主码,姓名取值唯一。,CREATE TABLE Student,(,Sno,CHAR(9) PRIMARY KEY,,,/*,列级完整性约束条件*,/,Sname,CHAR(20) UNIQUE,,,/*,Sname,取唯一值*,/,Ssex,CHAR(2),,,Sage SMALLINT,,,Sdept,CHAR(20),),;,主码,三、数据定义,9,附:使用企业管理器创建惟一约束。操作步骤如下:,打开企业管理器,选择要设置惟一约束的表,这里选择,mytable,表,并单击鼠标右键选择“设计表”命令。,在设计表窗口中单击快捷工具栏中的 按钮,打开“属性”对话框。,在“属性”对话框中选择“索引,/,键”选项卡,然后单击“新建”按钮,在“列名”下拉列表中选择要创建为惟一约束的列名称,并选中“创建,UNIQUE”,复选框和“约束”单选按钮。最后在“索引名”文本框中输入惟一约束名称即可。,关闭“属性”对话框,并单击工具栏中的 按钮保存设置,定义基本表,1,.,基本表的定义、删除,三、数据定义,10,定义基本表,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,),);,先修课,Cpno,是外码,被参照表是,Course,被参照列是,Cno,三、数据定义,11,定义基本表,1,.,基本表的定义、删除,例,3,建立一个,“学生选课”表,SC,CREATE TABLE SC,(,Sno,CHAR(9),,,Cno,CHAR(4),,,Grade SMALLINT,,,PRIMARY KEY (,Sno,,,Cno,),,,/*,主码由两个属性构成,必须作为表级完整性进行定义*,/,FOREIGN KEY (,Sno,) REFERENCES,Student(Sno,),,,/*,表级完整性约束条件,,Sno,是外码,被参照表是,Student */,FOREIGN KEY (,Cno,) REFERENCES,Course(Cno,),/*,表级完整性约束条件,,Cno,是外码,被参照表是,Course*/,);,三、数据定义,12,删除基本表,1,.,基本表的定义、删除,DROP TABLE ,;,删除表是有限制的。,欲删除的基本表不能被其他表的约束所引用,如果存在依赖该表的对象,则此表不能被删除,例,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,;,三、数据定义,13,修改基本表,2,.,修改基本表,ALTER TABLE , ADD ,完整性约束, , DROP , ALTER COLUMN , ADD,完整性约束定义,;,例,6,向,Student,表增加“入学时间”列,其数据类型为日期型。,ALTER TABLE Student ADD,S_entrance,DATE,;,不论基本表中原来是否已有数据,新增加的列一律为空值。,例,7,将年龄的数据类型由字符型(假设原来的数据类型是字符型)改为整数。,ALTER TABLE Student ALTER COLUMN Sage INT,;,例,8,增加课程名称必须取唯一值的约束条件。,ALTER TABLE Course ADD,UNIQUE(Cname,);,三、数据定义,14,3,.,数据完整性,完整性约束条件的作用对象,列级约束,元组完整性约束,关系约束,约束定义,列取值,非空,约束, NOT NULL,例,:,sname,char(10) NOT NULL,表,主码,约束:在定义列时定义主码(仅用于单列主码),列定义,PRIMARY KEY,例,:,SNO char(7) PRIMARY KEY,在定义完列时定义主码(用于单列或多列主码),PRIMARY KEY,(,),例,:,PRIMARY KEY(SNO),PRIMARY KEY(SNO,,,CNO),三、数据定义,15,外码,引用约束,:,指明本表外码列引用的表及表中的主码列。, FOREIGN KEY,(,),REFERENCES ,(,),例,:,FOREIGN KEY,(,sno,),REFERENCES,学生表(,sno,),默认值约束,格式:,DEFAULT,默认值,例,:定义系的默认值为“计算机系”。,DEFAULT ,计算机系,CHECK,约束,格式:,CHECK (,约束表达式,),例,:定义成绩大于等于,0,。,CHECK ( grade = 0 ),3,.,数据完整性,约束定义,三、数据定义,16,UNIQUE,约束,在列级约束定义(仅用于单列约束),列定义,UNIQUE,例,:,SNAME char(7) UNIQUE,在表级约束定义(用于单列或多列组合约束),UNIQUE,(,),例,:,UNIQUE (SNO,,,CNO),CREATE TABLE Student,(,Sno,char(7) PRIMARY KEY,Sname,char(10) NOT NULL,Ssex,char(2),CHECK(Ssex,=,男,OR,Ssex,=,女,),Sage,tinyint,CHECK(Sage,=15 AND Sage=45),Sdept,char (20) DEFAULT ,计算机系,),3,.,数据完整性,约束定义,三、数据定义,练习:,将,student,表增加入学时间列,并设定默认值;,将性别列加上取值男或女的约束,并设定为非空。,将,course,表中的,Cname,设定为唯一的。,17,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 char(10),primary,key(a,b,),);,D. create table test1,(,a char(10) primary,key,b,char(10) primary,key,c,char,(,10,);,第二次上机作业,1,:,关系模式:,供应商(单位编号,单位名称,地址,负责人,,)单位名称唯一,地址默认为,成都,项目(项目号,项目名,,)项目名非空,零件(零件编号,零件名称,,),供应(单位编号,项目号,零件编号,供应量),分别设定每张表的主码、外码,小结,18,
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 小学资料


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!