SQL概述及数据定义

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
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值