结构化查询语言SQL-关系数据库标准语言

1. 数据定义语言DDL

模式、表、视图、索引,其中只有表和索引有修改定义的操作。

1.1 模式定义与删除

  1. 模式定义:
CREATE SCHEMA <模式名> AUTHORIZATION <用户名>;
  1. 创建模式的同时可以在这个模式定义中进一步创建基本表、视图,定义授权。(好像没有索引)。
CREATE SCHEMA <模式名> AUTHORIZATION <用户名> [<表定义子句>|<视图定义子句>|<授权定义子句>];
  1. 删除模式:
DROP SCHEMA <模式名> <CASCADE|RESTRICT>

CASCADERESTRICT必须选择一个。

CASCADE(级联):在删除模式的同时把该模式中所有的数据库对象全部删除;

RESTRICT(限制):如果该模式中已经定义了下属的数据库对象,比如表、视图等,则拒绝该删除语句的执行,只有当该模式下没有任何下属对象的时候才能执行DROP SCHEMA操作。

  1. 例题:
  • 用户WANG定义一个学生-课程模式S-T
CREATE SCHEMA S-T AUTHORIZATION WANG
  • 为用户WANG创建了一个模式TEST,并且在其中定义一个表TAB1
CREATE SCHEMA TEST AUTHORIZATION WANG
CREATE TABLE TAB1(COL1 SMALLINT,
				  COL2 INT,
				  COL3 CHAR(20),
				  COL4 NUMERIC(10,3),
				  COL5 DECIMAL(5,2)
				  );
  • 删除模式ZHANG,同时该模式中已经定义的表 TAB1也删除。
DROP SCHEMA ZHANG CASCADE

1.2 表的定义、删除和修改

  1. 定义基本表
CREATE TABLE <表名>(<列名> <数据类型>[ <列级完整性约束条件> ]
      			    [,<列名> <数据类型>[ <列级完整性约束条件>] ][,<表级完整性约束条件> ] );

  1. 修改基本表
ALTER TABLE <表名>
[ ADD[COLUMN] <新列名> <数据类型> [ 完整性约束 ] ]
[ ADD <表级完整性约束>]
[ DROP [COLUMN] <列名> [CASCADE| RESTRICT] ]
[ DROP CONSTRAINT<完整性约束名>[ RESTRICT | CASCADE ] ]
[ALTER COLUMN <列名><数据类型> ] ;

DROP CONSTRAINT:删除指定的完整性约束

  1. 删除基本表
DROP TABLE <表名> [ CASCADE | RESTRICT ]
  1. 模式与表

一个模式包含多个表。

  • 一:在表名中明显给出模式名
CREATE TABLE "S-T".Student(.....)
  • 二:在创建模式语句中同时创建表
  • 三:设置所属模式,这样在创建表名的时候就必给出模式名
    若没有指定,系统会根据 搜索路径 确定该对象所属模式。
    关系数据库管理系统会使用模式列表中第一个存在的模式作为数据库对象的模式名。
    显示当前搜索路径:
SHOW search_path

数据库管理员可以设置搜索路径:

SET search_psth TO "S-T",PUBLIC;

然后定义基本表:

CREATE TABLE Student(...)
  1. 例题
  • 建立一个“课程”表Course
CREATE TABLE Course(
	Cno CHAR(4) PRIMARY KEY,// 列级完整性约束
	Cname CHAR(40) NOT NULL,
	Cpno CHAR(4),
	Ccredit SMALLINT,
	FOREIGN KEY (Cpno) REFERENCES Course(Cno) //表级完整性约束
);
  • 建立一个学生选课表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中域的基本概念用数据类型来实现。

DATE:YYYY-MM-DD
TIME:HH:MM:SS

  • 向Student表增加“入学时间”列,其数据类型为日期型;将年龄的数据类型由字符型(假设原来的数据类型是字符型)改为整数;增加课程名称必须取唯一值的约束条件
ALTER TABLE Student ADD S_entrance DATE;
ALTER TABLE Student ALTER COLUMN Sage INT;
ALTER TABLE Course ADD UNIQUE(Cname);
  • 删除Student表
DROP TABLE Student CASCADE;
DROP TABLE Student;

1.3 索引的建立和删除

建立索引是加快查询速度的有效手段。

  1. 建立索引
CREATE [UNIQUE] [CLUSTER] INDEX <索引名>
ON <表名>(<列名> [<次序>][,<列名> [<次序>]]...);

UNIQUE:索引的每一个索引值只对应唯一记录。
CLUSTER:要建立的索引是聚簇索引。
次序:默认升序ASC,降序DESC
2. 修改索引

ALTER INDEX <旧索引名> RENAME TO <新索引名>;
  1. 删除索引
DROP INDEX <索引名>
  1. 例题
CREATE  UNIQUE INDEX Student ON Student(Sno);
CREATE UNIQUE INDEX SCno ON SC(Sno ASC, Cno DESC);
// 将SC表的SCno索引名改为SCSno
ALTER INDEX SCno RENAME TO SCSno;
DROP INDEX  Stusname;

2. 数据操纵语言DML

增删改查

3. 数据控制语言

grant、revoke、deny

https://blog.csdn.net/jiashiqihh?type=blog

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值