关系数据库标准语言SQL

SQL概述
❖SQL(Structured Query Language)
结构化查询语言,是关系数据库的标准语言
❖SQL是一个通用的、功能极强的关系数据库语言
SQL的特点
1.综合统一
◼ 集数据定义语言(DDL),数据操纵语言(DML),
数据控制语言(DCL)功能于一体。
◼ 可以独立完成数据库生命周期中的全部活动:
➢ 定义关系模式,插入数据,建立数据库;
➢ 对数据库中的数据进行查询和更新;
➢ 数据库重构和维护
➢ 数据库安全性、完整性控制等
◼ 用户数据库投入运行后,可根据需要随时逐步修改模
式,不影响数据的运行。
◼ 数据操作符统一
2.高度非过程化
❖非关系数据模型的数据操纵语言“面向过程”,
必须制定存取路径
❖SQL只要提出“做什么”,无须了解存取路径。
❖ 存取路径的选择以及SQL的操作过程由系统自动
完成。
3.面向集合的操作方式
❖非关系数据模型采用面向记录的操作方式,操作
对象是一条记录
❖SQL采用集合操作方式
➢ 操作对象、查找结果可以是元组的集合
➢ 一次插入、删除、更新操作的对象可以是元组的集合
4.以同一种语法结构提供多种使用方式
❖SQL是独立的语言
能够独立地用于联机交互的使用方式
❖SQL又是嵌入式语言
SQL能够嵌入到高级语言(例如C,C++,Java)程
序中,供程序员设计程序时使用
5.语言简洁,易学易用
❖ SQL功能极强,完成核心功能只用了9个动词。
SQL的基本概念(续)
❖ 基本表
◼ 本身独立存在的表
◼ SQL中一个关系就对应一个基本表
◼ 一个(或多个)基本表对应一个存储文件
◼ 一个表可以带若干索引
❖ 存储文件
◼ 逻辑结构组成了关系数据库的内模式
◼ 物理结构是任意的,对用户透明
❖ 视图
◼ 从一个或几个基本表导出的表
◼ 数据库中只存放视图的定义而不存放视图对应的数据
◼ 视图是一个虚表
◼ 用户可以在视图上再定义视图
基本表的定义、删除与修改
❖定义基本表
CREATE TABLE <表名> (<列名> <数据类型>[ <列级完整性约束条件> ] [,<列名> <数据类型>[ <列级完整性约束条件>] ] …[,<表级完整性约束条件> ] ); ◼ <表名>:所要定义的基本表的名字
◼ <列名>:组成该表的各个属性(列)
◼ <列级完整性约束条件>:涉及相应属性列的完整性约束条件
◼ <表级完整性约束条件>:涉及一个或多个属性列的完整性约
束条件
◼ 如果完整性约束条件涉及到该表的多个属性列,则必须定义
在表级上,否则既可以定义在列级也可以定义在表级。
学生表Student
[例3.5] 建立“学生”表Student。学号是主码,姓名取值唯一。
CREATE TABLE Student
(Sno CHAR(9) PRIMARY KEY,
/* 列级完整性约束条件,Sno是主码*/
Sname CHAR(20) UNIQUE, /* Sname取唯一值*/
Ssex CHAR(2),
Sage SMALLINT,
Sdept CHAR(20)
);
主码
UNIQUE
约束
课程表Course
[例3.6 ] 建立一个“课程”表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
学生选课表SC
[例7] 建立一个“学生选课”表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*/
);

模式与表
❖每一个基本表都属于某一个模式
❖一个模式包含多个基本表
❖定义基本表所属模式
◼ 方法一:在表名中明显地给出模式名
Create table"S-T".Student(…);
/模式名为 S-T/
Create table “S-T”.Cource(…);
Create table “S-T”.SC(…);
◼ 方法二:在创建模式语句中同时创建表
◼ 方法三:设置所属的模式

修改基本表
ALTER TABLE <表名> [ ADD <新列名> <数据类型> [ 完整性约束 ] ] [ DROP <完整性约束名> ] [ ALTER COLUMN<列名> <数据类型> ];
修改基本表(续)
[例8]向Student表增加“入学时间”列,其数据类型为日期型。
ALTER TABLE Student ADD S_entrance DATE; ◼ 不论基本表中原来是否已有数据,新增加的列一律为空值。 [例9]将年龄的数据类型由字符型(假设原来的数据类型是字符型)改为整数。
ALTER TABLE Student ALTER COLUMN Sage INT; [例10]增加课程名称必须取唯一值的约束条件。
ALTER TABLE Course ADD UNIQUE(Cname);

删除基本表
DROP TABLE <表名>[RESTRICT| CASCADE];
◼ RESTRICT:删除表是有限制的。
➢ 欲删除的基本表不能被其他表的约束所引用
➢ 如果存在依赖该表的对象,则此表不能被删除
◼ CASCADE:删除该表没有限制。
➢ 在删除基本表的同时,相关的依赖对象一起删除
删除基本表(续) [例11] 删除Student表
DROP TABLE Student CASCADE ;
◼ 基本表定义被删除,数据被删除
◼ 表上建立的索引、视图、触发器等一般也将被删除

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值