当前位置:网站首页>结构化查询语言SQL-关系数据库标准语言
结构化查询语言SQL-关系数据库标准语言
2022-07-31 10:40:00 【silhouette10】
结构化查询语言SQL-关系数据库标准语言
1. 数据定义语言DDL
模式、表、视图、索引,其中只有表和索引有修改定义的操作。
1.1 模式定义与删除
- 模式定义:
CREATE SCHEMA <模式名> AUTHORIZATION <用户名>;
- 创建模式的同时可以在这个模式定义中进一步创建基本表、视图,定义授权。(好像没有索引)。
CREATE SCHEMA <模式名> AUTHORIZATION <用户名> [<表定义子句>|<视图定义子句>|<授权定义子句>];
- 删除模式:
DROP SCHEMA <模式名> <CASCADE|RESTRICT>
CASCADE
和RESTRICT
必须选择一个。
CASCADE
(级联):在删除模式的同时把该模式中所有的数据库对象全部删除;
RESTRICT
(限制):如果该模式中已经定义了下属的数据库对象,比如表、视图等,则拒绝该删除语句的执行,只有当该模式下没有任何下属对象的时候才能执行DROP SCHEMA
操作。
- 例题:
- 用户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 表的定义、删除和修改
- 定义基本表
CREATE TABLE <表名>(<列名> <数据类型>[ <列级完整性约束条件> ]
[,<列名> <数据类型>[ <列级完整性约束条件>] ]
…
[,<表级完整性约束条件> ] );
- 修改基本表
ALTER TABLE <表名>
[ ADD[COLUMN] <新列名> <数据类型> [ 完整性约束 ] ]
[ ADD <表级完整性约束>]
[ DROP [COLUMN] <列名> [CASCADE| RESTRICT] ]
[ DROP CONSTRAINT<完整性约束名>[ RESTRICT | CASCADE ] ]
[ALTER COLUMN <列名><数据类型> ] ;
DROP CONSTRAINT
:删除指定的完整性约束
- 删除基本表
DROP TABLE <表名> [ CASCADE | RESTRICT ]
- 模式与表
一个模式包含多个表。
- 一:在表名中明显给出模式名
CREATE TABLE "S-T".Student(.....)
- 二:在创建模式语句中同时创建表
- 三:设置所属模式,这样在创建表名的时候就必给出模式名
若没有指定,系统会根据 搜索路径 确定该对象所属模式。
关系数据库管理系统会使用模式列表中第一个存在的模式作为数据库对象的模式名。
显示当前搜索路径:
SHOW search_path
数据库管理员可以设置搜索路径:
SET search_psth TO "S-T",PUBLIC;
然后定义基本表:
CREATE TABLE Student(...)
- 例题
- 建立一个“课程”表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 索引的建立和删除
建立索引是加快查询速度的有效手段。
- 建立索引
CREATE [UNIQUE] [CLUSTER] INDEX <索引名>
ON <表名>(<列名> [<次序>][,<列名> [<次序>]]...);
UNIQUE
:索引的每一个索引值只对应唯一记录。CLUSTER
:要建立的索引是聚簇索引。
次序:默认升序ASC,降序DESC
2. 修改索引
ALTER INDEX <旧索引名> RENAME TO <新索引名>;
- 删除索引
DROP INDEX <索引名>
- 例题
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
边栏推荐
- 3D激光SLAM:LeGO-LOAM论文解读---完整篇
- 【Web技术】1397- 深入浅出富文本编辑器
- Intranet Penetration Learning (IV) Domain Lateral Movement - SMB and WMI Service Utilization
- 新人学习小熊派华为iot介绍
- 如何判断自己是否适合IT行业?方法很简单
- csdn文件导出为pdf
- 众多mock工具,这一次我选对了
- 透过开发抽奖小程序,体会创新与迭代
- AtCoder—E - Σ[k=0..10^100]floor(X/10^k
- Sql optimization summary!detailed!(Required for the latest interview in 2021)
猜你喜欢
【Web技术】1397- 深入浅出富文本编辑器
NowCoderTOP17-22 Binary search/sort - continuous update ing
Insertion and deletion of doubly linked list
darknet 训练分类网络
Day113. Shangyitong: user authentication, Alibaba Cloud OSS, patient management
SQLServer2019安装(Windows)
NowCoderTOP28-34 binary tree - continuous update ing
SQLServer2019 installation (Windows)
如何判断自己是否适合IT行业?方法很简单
Master SSR
随机推荐
【23提前批】北森云计算-测开面经
Android安全专题(三)JNI混淆
v-model的原理
【LeetCode】1161.最大层内元素和
【LeetCode】203.移除链表元素
众多mock工具,这一次我选对了
DC-7-vulnhub
C#多态的实现
Redis缓存面临的缓存穿透问题
【LeetCode】21. 合并两个有序链表
湖仓一体电商项目(二):项目使用技术及版本和基础环境准备
unity-shader-2
csdn file export to pdf
我们能做出来数据库吗?
Web系统常见安全漏洞介绍及解决方案-sql注入
尚医通【预约挂号系统】总结
(C language) program environment and preprocessing
unity computeshader的可读写buffer
Redis-基础
Web系统常见安全漏洞介绍及解决方案-XSS攻击