SQL功能极强,完成核心功能只用了了9个动词
SQL功能 | 动词 |
---|---|
数据查询 | SELECT |
数据定义 | CREATE,DROP,ALTER |
数据操作 | INSERT,DELETE,UPDATE |
数据控制 | GRANT\REVOKE |
(3)SQL的基本概念
- SQL支持关系数据库
基本表
- 本身独立存在的表
- SQL中一个关系就对应一个基本表
- 一个(或多个)基本表对应一个存储文件
- 一个表可以带若干索引
存储文件
- 逻辑结构组成了关系数据库的内模式
- 物理结构是任意的,对用户透明
视图
- 从一个或几个基本表导出的表
- 数据库只存放使徒的定义而不存放试图对应的数据
- 视图是一个虚表
- 用户可以在视图上在定义视图
3.数据字典
- 数据字典是关系数据库管系统内部的一组系统表,它记录了数据库中的所有定义信息,包括关系模式定义、视图定义、索引定义、完整性约束定义、各类用户对数据库的操作权限、统计信息等
- 关系数据库管理系统在执行SQL的数据定义语句时,实际上就是在更新数据库字典表中的相应信息
- 在进行查询优化和查询处理时,数据字典中的信息是其重要依据
4.数据定义
(1)数据定义概览
- SQL的数据定义功能:模式定义、表定义、视图和索引的定义
(2)模式的定义与删除-SCHEMA
定义模式实际上定义了一个命名空间
- 在这个空间中可以定义该模式包含的数据库对象,例如基本表、视图、索引
- 在CREATE SCHEMA中可以接受CREATE TABLE,CREATE VIEW 和GRANT子句
- CREATE SHCEMA<模式名> AUTHORIZATION<'用户名>[<表定义子句>|<视图定义子句>|<授权定义子句>]
- 如果没有指定<模式名>,那么<模式名>隐含为<用户名>
①定义模式
dbo database owner 数据库的创建者,创建该对象的用户 guest顾客,能够访问数据库中对象的数据,要求dbo分配权限给guest,一般给他查看的权限select
CREATE SCHEMA "S-T" AUTHORIZATION BitHachi;
为用户BitHachi定义了一个模式S-T
基本表的定义、删除与修改
如果完整性约束条件涉及到该表的多个属性列,则必须定义在表级上,否则既可以定义在列级也可以定义在表级。
create table course(
cno char(4) primary key,
cname char(40),
cpno char(4),
creadit smallint,
foreign key(cpno) references course(con)
);
建立一个学生选课表SC
CREATE TABLE SC
(Sno CHAR(9),
Cno CHAR(4),
Grade SMALLINT,
PRIMARY KEY(Sno,Cno),
FOREIGN KEY(Sno)REFERENCES Student(Sno),
FOREIGN KEY(Cno) REFERENCES Course(Cno)
);
数据类型
- SQL中域的概念用数据类型来实现
- 定义表的属性时,要指明其数据类型及长度
- 选用哪种数据类型:取值范围 要做哪些运算
向Student表增加“入学时间”列,其数据类型为日期型。
ALTER TABLE Student ADD S_entrance DATE;
将年龄的数据类型由字符型(假设原来的数据类型是字符型)改为整数。
ALTER TABLE Student COLUMN Sage INT;
删除表
RESTRICT:删除表是有限制的。
欲删除的基本表不能被其他表的约束所引用
如果存在依赖该表的对象,则此表不能被删除
CASCADE:删除该表没有限制。
在删除基本表的同时,相关的依赖对象一起删除
删除Student表
DROP TABLE Student CASCADE;
若表上建有视图,选择RESTRICT时表不能删除
CREATE VIEW IS_Student
AS
SELECT Sno,Sname,Sage
FROM student
WHERE Sdept='IS';
DROP TABLE Student RESTRICT