第3章-SQL语言基础课件_第1页
第3章-SQL语言基础课件_第2页
第3章-SQL语言基础课件_第3页
第3章-SQL语言基础课件_第4页
第3章-SQL语言基础课件_第5页
已阅读5页,还剩48页未读 继续免费阅读

下载本文档

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

文档简介

数据库原理与实践教程

——SQLServer2005第3章SQL语言基础及数据定义功能2023/7/271第3章SQL语言基础及数据定义功能3.1基本概念3.2SQL的数据类型3.3数据定义功能2023/7/2723.1基本概念3.1.1SQL语言的发展3.1.2SQL语言的特点3.1.3SQL语言功能概述2023/7/2733.1.1SQL语言的发展1986年10月由美国ANSI公布最早的SQL标准。1989年4月,ISO提出了具备完整性特征的SQL,称为SQL-89。1992年11月,ISO又公布了新的SQL标准,称为SQL-92(以上均为关系形式)。

1999年颁布SQL-99,是SQL92的扩展。2023/7/2743.1.2SQL语言的特点1.一体化2.高度非过程化3.简洁4.以多种方式使用2023/7/2753.1.3SQL语言功能概述SQL功能命令动词数据查询SELECT数据定义CREATE、DROP、ALTER数据操纵INSERT、UPDATE、DELETE数据控制GRANT、REVOKE四部分:数据定义功能、数据控制功能、数据查询功能和数据操纵功能。

2023/7/2763.2SQL的数据类型数值型字符串型日期时间型货币型2023/7/277数值型准确型整数Bigint:8字节,Int:4字节Smallint:2字节,Tinyint:1字节(0~255)

Bit:1位,存储1或0小数Numeric(p,q)或Decimal(p,q),其中:p为数字位长度,q:小数位长度。近似型

Float:8字节

Real:4字节2023/7/278字符串型普通编码字符串类型统一字符编码字符串类型二进制字符串类型2023/7/279普通编码字符串类型char(n):定长存储,n<=8000varchar(n):不定长存储(按实际长度存储),长度最大不超过n,n<=8000注:n为字符个数text:存储大于8000字节的文本2023/7/2710统一字符编码字符串类型nchar(n):定长存储,n<=4000nvarchar(n):不定长存储,长度最大不超过n,n<=4000ntext:存储大于8000字节的文本特点:每个字符占两个字节2023/7/2711二进制字符串类型binary(n):固定长度,n<=8000varbinary(n):可变长度,n<=8000注:n为二进制数据的字节数image:大容量、可变长二进制字符数据,可用于存储文件。2023/7/2712日期时间型Datetime:8字节,年月日时分秒毫秒 (例:’2001/08/0310:30:00.000’

)SmallDateTime:4字节,年月日时分(例:’2001/08/0310:30:00’

)几种输入格式:英文数字格式:Oct252001 数字加分隔符格式:2001-10-25 纯数字格式:2023/7/2713货币类型Money:8字节,精确到小数点后4位。Smallmoney:4字节,精确到小数点后4位。可以带有适当的货币符号。例如,100英镑可表示为£100。2023/7/27143.3数据定义功能3.3.1基本表3.3.3数据完整性2023/7/27153.3.1基本表1.定义基本表CREATETABLE<表名>(<列名><数据类型>[列级完整性约束定义]{,<列名><数据类型>[列级完整性约束定义]…}[,表级完整性约束定义])

2023/7/2716可定义的约束NOTNULL:限制列取值非空。DEFAULT:给定列的默认值。UNIQUE:限制列取值不重。CHECK:限制列的取值范围。PRIMARYKEY:指定本列为主码。FOREIGNKEY:定义本列为引用其他表的外码。使用形式为:[FOREIGNKEY(<外码列名>)]REFERENCES<外表名>(<外表列名>)

2023/7/2717几点说明NOTNULL和DEFAULT只能是列级完整性约束;其他约束均可在表级完整性约束处定义。注意以下几点:第一,如果CHECK约束是定义多列之间的取值约束,则只能在表级完整性约束处定义;第二,如果表的主码由多个列组成,则也只能在表级完整性约束处定义,并将主码列用括号括起来,即:PRIMARYKEY(列1{[,列2]…});第三,如果在表级完整性约束处定义外码,则“FOREIGNKEY(<外码列名>)”部分不能省。2023/7/2718约束定义

①列取值非空约束<列名><类型>NOTNULL

例:snamechar(10)NOTNULL2023/7/2719约束定义(续)②表主码约束在定义列时定义主码(仅用于单列主码)列定义PRIMARYKEY例:SNOchar(7)PRIMARYKEY在定义完列时定义主码(用于单列或多列主码)PRIMARYKEY

(<列名序列>) 例:PRIMARYKEY(SNO)PRIMARYKEY(SNO,CNO)2023/7/2720约束定义(续)③外码引用约束指明本表外码列引用的表及表中的主码列。

[FOREIGNKEY(<本表列名>)]REFERENCES<外表名>(<外表主码列名>)例:

FOREIGNKEY(sno)

REFERENCES学生表(sno)

2023/7/2721创建学生表CREATETABLEStudent(Snochar(7)PRIMARYKEY,Snamechar(10)NOTNULL,Ssexchar(2),Sagetinyint,Sdeptchar(20))2023/7/2722创建课程表CREATETABLECourse(Cnochar(10)NOTNULL,Cnamechar(20)NOTNULL,Ccredittinyint,Semestertinyint,PRIMARYKEY(Cno))

2023/7/2723创建SC表CREATETABLESC(Snochar(7)NOTNULL,Cnochar(10)NOTNULL,Gradetinyint,XKLBchar(4),PRIMARYKEY(Sno,Cno),FOREIGNKEY(Sno)REFERENCESStudent(Sno),FOREIGNKEY(Cno)REFERENCESCourse(Cno))2023/7/27242.修改基本表在定义完表之后,如果需求有变化,比如添加列、删除列或修改列定义,可以使用ALTERTABLE语句实现。ALTERTABLE语句可以对表添加列、删除列、修改列的定义、定义主码、外码,也可以添加和删除约束。2023/7/2725修改表结构语法ALTERTABLE<表名>[ALTERCOLUMN<列名><新数据类型>]|[ADD[COLUMN]<列名><数据类型>|[DROPCOLUMN<列名>]|[ADDPRIMARYKEY(列名[,…n])]|[ADDFOREIGNKEY(列名)REFERNECES表名(列名)]2023/7/2726示例例1.为SC表添加“修课类别”列,此列的定义为:Typenchar(2)ALTERTABLESCADDTypenchar(2)NULL

2023/7/2727示例例2.将新添加的Type的类型改为nchar(4)。ALTERTABLESCALTERCOLUMNTypenchar(4)2023/7/2728示例例3.删除SC表的Type列。ALTERTABLESCDROPCOLUMNType

2023/7/27293.删除基本表删除表时会将与表有关的所有对象一起删掉,包括表中的数据。删除表的语句格式为:DROPTABLE<表名>{[,<表名>]…}例:删除test表的语句为:DROPTABLEtest2023/7/27303.3.3数据完整性完整性约束条件的作用对象实现数据完整性2023/7/2731完整性约束条件的作用对象完整性检查是围绕完整性约束条件进行的,因此,完整性约束条件是完整性控制机制的核心。完整性约束条件的作用对象可以是表、元组和列。列级约束元组约束关系约束2023/7/2732列级约束列级约束主要是对列的类型、取值范围、精度等的约束,具体包括:对数据类型的约束:包括数据类型、长度、精度等。对数据格式的约束:如规定学号的前两位表示学生的入学年份,第三位表示系的编号,第四位表示专业编号,第五位代表班的编号等等。对取值范围的约束:如学生的成绩取值范围为0~100。对空值的约束。

2023/7/2733元组约束元组的约束是元组中各个字段之间的联系的约束,如:开始日期小于结束日期,最低工资小于最高工资。2023/7/2734关系约束指若干元组之间、关系之间的联系的约束。比如:学号的取值不能重复也不能取空值学生修课表中的学号的取值受学生表中的学号取值的约束

2023/7/2735实现数据完整性声明完整性

在表定义时声明使用约束、缺省值(DEFAULT)等由数据库管理系统自动加以保证过程完整性

在服务器端用触发器(trigger)实现2023/7/2736实现约束1.PRIMARYKEY约束2.UNIQUE约束3.FOREIGNKEY约束4.DEFAULT约束5.CHECK约束2023/7/2737表示例CREATETABLE工作表(

工作编号CHAR(6)NOTNULL,

最低工资NUMERIC(7,2),

最高工资NUMERIC(7,2))

CREATETABLE职工表(

职工编号CHAR(7)NOTNULL,

姓名NCHAR(5)NOTNULL,

工作编号CHAR(6),

工资NUMERIC(7,2),

电话号码CHAR(8))2023/7/2738PRIMARYKEY约束保证实体完整性每个表有且只有一个PRIMARYKEY约束格式:ALTERTABLE表名

ADD[CONSTAINT约束名]

PRIMARYKEY(列名[,…n])2023/7/2739示例对职工表和工作表分别添加主码约束ALTERTABLE职工表

ADDCONSTRAINTPK_EMPPRIMARYKEY(职工编号)ALTERTABLE工作表

ADDCONSTRAINTPK_JOBPRIMARYKEY(工作编号)2023/7/2740UNIQUE约束确保在非主键列中不输入重复值。应用在客观具有唯一性质的列上,如身份证号、社会保险号等。格式:ALTERTABLE表名

ADD[CONSTRAINT约束名]UNIQUE(<列名>[,…n])2023/7/2741示例为职工表的“电话号码”列添加UNIQUE约束。ALTERTABLE职工表

ADDCONSTRAINTUK_SIDUNIQUE(电话号码)2023/7/2742FOREIGNKEY约束用于建立和加强两个表数据之间的连接的一列或多列格式:ALTERTABLE表名

ADD[CONSTRAINT约束名]FOREIGNKEY(<列名>)REFERENCES引用表名(<列名>)2023/7/2743示例为职工表的工作编号添加外码引用约束,此列引用工作表的工作编号列。ALTERTABLE职工

ADDCONSTRAINTFK_job_idFOREIGNKEY(工作编号)REFERENCES工作表(工作编号)2023/7/2744

DEFAULT约束当向表中插入数据时,如果没有为定义了DEFAULT的列提供值,则是隐式要求为此列使用默认值。一个Default只能约束一列。格式:ALTERTABLE表名

ADD[CONSTRAINT约束名]DEFAULT默认值FOR列名2023/7/2745示例定义职工表的工资的默认值为1000。ALTERTABLE职工

ADDCONSTRAINTDF_SALARYDEFAULT1000FOR工资2023/7/2746CHECK约束通过限制输入到列中的值来强制域的完整性。可定义同表多列之间的约束关系格式:ALTERTABLE表名

ADD[CONSTRAINT约束名]CHECK(逻辑表达式)2023/7/2747示例1在职工表中,添加限制职工的工资必须大于等于800的约束。ALTERTABLE职工表

ADDCONSTRAINTCHK_SalaryCHECK(工资>=800)2023/7/2748示例2添加限制工作表的最低

温馨提示

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

评论

0/150

提交评论