第三章 关系数据库标准语言SQL 知识梳理

3.1SQL概述

  • SQL语言:是结构化查询语言。

  • SQL的特点:SQL集数据查询(data query)、数据操纵(data manipulation)、数据定义(data definition)、和数据控制(data control)功能于一体。

  • SQL的基本概念
    SQL支持关系数据库三级模式结构。其中外模式包括若干视图表和部分基本表,数据库模式包括若干基本表,内模式包括若干存储文件
    在这里插入图片描述

3.2数据定义

SQL的数据定义功能包括模式定义、表定义、视图和索引定义。在这里插入图片描述

  • 一个关系数据库管理系统的实例中可以创建多个数据库,一个数据库中可以建立多个模式,一个模式下包括多个表,视图,和索引等数据库对象。

  • 模式的定义SQL语句:CREATE SCHEMA <模式名> AUTHORIZATION <用户名>

  • 模式的删除SQL语句:DROP SCHEMA <模式名> <CASCADE|RESTRICT>(CASCADE级联|RESTRICT限制)

  • 基本表定义SQL语句:CREATE TABLE <表名> (
    <列名> <数据类型> [列级完整性约束条件] ,
    <列名> <数据类型> [列级完整性约束条件] ,


    例:
    建立一个学生表(Student)
    CREATE TABLE Student (
    Sno CHAR(19) PRIMARY KEY,
    Sname CHAR(20) UNIQUE,
    Ssex CHAR(2),
    Sage SMALLINT,
    Sdept CHAR(20)
    );
    例:
    建立课程表(Course)
    CREATE TABLE Course (
    Cno CHAR(9) PRIMARY KEY,
    Cname CHAR(40) NOT NULL,
    Cpno CHAR(4),
    Ceredit SMALLINT,
    FOREIGN KEY(Cpno) REFERENCES Course(Cno)
    /表的完整性约束条件,Cpno是外码,被参照表是Course,被参照列为Cno/
    );
    例:
    建立学生选课表SC
    CREATE TABLE SC(
    Sno CHAR(9),
    Cno CHAR(4),
    Grade SMALLINT,
    PRIMARY KEY(Sno,Cno),
    FOREGIN KEY(Sno) REFERENCES Student(Sno)
    FOREGIN KEY(Cno) REFERENCES Course(Cno)
    )

  • 数据类型
    在这里插入图片描述
    在这里插入图片描述

  • 修改基本表
    修改基本表SQL语言:
    ALTER TABLE <表名>
    [ADD [COLUMN] <新列名> <数据类型> [完整性约束]]
    [ADD <表级完整性约束>]
    [DROP [COLUMN] <列名> [CASCADE|RESTRICT]]
    [DROP CONSTRAINT <完整性约束名> [RESTRICT|CASCADE]]
    [ALTER COLUMN <列名> <数据类型>]

  • 删除基本表
    删除基本表SQL语言:
    DROP TABLE <表名> [RESTRICT|CASCADE]
    注释:选择RESTRICT,则该表的删除是有限制条件的。欲删除的基本表不能被约束所引用(如CHECK,FOREIGN KEY等约束),不能有视图,不能有触发器,不能有存储过程或函数等,如果存在这些依赖该表的对象,则此表不能被删除。
    选择CASCADE,则该表删除没有限制条件,在删除表的同时,相对应的对象都会被一起删除。

  • 索引
    1.建立索引SQL语言:
    CREATE [UNIQUE] [CLUSTER] INDEX <索引名> ON<表名>(<列名> [<次序>]…)
    注释:次序是指定索引值得排列次序,可以选着ASC(升序)和DESC(降序)。
    UNIQUE表示此索引的每一个索引值对应唯一的数据记录。
    CLUSTER表示建立的索引是聚簇索引。

    2.修改索引SQL语言:
    ALTER INDEX <旧索引名> RENAME TO<新索引名>
    3.删除索引SQL语言:
    DROP INDEX <索引名>

  • 数据字典
    数据字典是关系数据管理系统内部的一组系统表,它记录了数据库中定义的所有信息,包括关系模式定义、视图定义、索引定义、完整性约束定义、各类用户对数据库权限、统计信息等。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值