• 第22课 高级SQL特性


    第22课 高级SQL特性

    22.1 约束

    22.1.1 主键

    主键是一种特殊的约束,用来保证一列(或一组列)中的值是唯一的,而且永不改动。换句话说,表中的一列(或多个列)的值唯一标识表中的每一行。

    一种定义主键的方法是创建它,如下所示:

    CREATE TABLE Vendors 
    (
    vend_id         CHAR(10)       NOT NULL PRIMARY KEY, 
    vend_name       CHAR(50)       NOT NULL,
    vend_address    CHAR(50)       NULL,
    vend_city       CHAR(50)       NULL,
    vend_state      CHAR(5)        NULL,
    vend_zip        CHAR(10)       NULL,
    vend_country    CHAR(50)       NULL
    );
    

    在此例子中,给表的vend_id列定义添加关键字PRIMARY KEY,使其成为主键。

    ALTER TABLE Vendors 
    ADD CONSTRAINT PRIMARY KEY (vend_id);
    

    这里定义相同的列为主键,但使用的是CONSTRAINT语法。

    22.1.2 外键

    外键是表中的一列,其值必须列在另一表的主键中。

    下面是定义这个外键的方法:

    CREATE TABLE Orders
    (
        order_num     INTEGER     NOT NULL PRIMARY KEY,
        order_date    DATETIME    NOT NULL,
        cust_id       CHAR(10)    NOT NULL REFERENCES Customers(cust_id)
    );
    

    其中的表定义使用了REFERENCES关键字,它表示cust_id中的任何值都必须是Customers表的cust_id中的值。

    相同的工作也可以在ALTER TABLE语句中用CONSTRAINT语法来完成:

    ALTER TABLE Orders
    ADD CONSTRAINT
    FOREIGN KEY (cust_id) REFERENCES Customers (cust_id)
    

    提示:外键有助防止意外删除
    在定义外键后,DBMS不允许删除在另一个表中具有关联行的行。由于需要一系列的删除,因而利用外键可以防止意外删除数据。

    22.1.3 唯一约束

    唯一约束用来保证一列(或一组列)中的数据是唯一的。它们类似于主键,但存在以下重要区别。

    • 表可包含多个唯一约束,但每个表只允许一个主键。
    • 唯一约束列可包含NULL值。
    • 唯一约束列可修改或更新。
    • 唯一约束列的值可重复使用。
    • 与主键不一样,唯一约束不能用来定义外键。

    22.1.4 检查约束

    检查约束用来保证一列(或一组列)中的数据满足一组指定的条件。检查约束的常见用途有以下几点。

    • 检查最小或最大值。例如,防止0个物品的订单(即使0是合法的数)。
    • 指定范围。例如,保证发货日期大于等于今天的日期,但不超过今天起一年后的日期。
    • 只允许特定的值。例如,在性别字段中只允许M或F。
    CREATE TABLE OrderItems
    (
        order_num     INTEGER     NOT NULL,
        order_item    INTEGER     NOT NULL,
        prod_id       CHAR(10)    NOT NULL,
        quantity      INTEGER     NOT NULL CHECK (quantity > 0),
        item_price    MONEY       NOT NULL
    );
    

    利用这个约束,任何插入(或更新)的行都会被检查,保证quantity大于0。

    检查名为gender的列只包含M或F,可编写如下的ALTER TABLE语句:

    ADD CONSTRAINT CHECK (gender LIKE '[MF]')
    

    22.2 索引

    索引用来排序数据以加快搜索和排序操作的速度。

    索引用CREATE INDEX语句创建(不同DBMS创建索引的语句变化很大)。

    CREATE INDEX prod_name_ind
    ON PRODUCTS (prod_name);
    

    索引必须唯一命名。这里的索引名prod_name_ind在关键字CREATE INDEX之后定义。ON用来指定被索引的表,而索引中包含的列(此例中仅有一列)在表名后的圆括号中给出。

    22.3 触发器

    触发器是特殊的存储过程,它在特定的数据库活动发生时自动执行。触发器可以与特定表上的INSERT、UPDATE和DELETE操作(或组合)相关联。

    与存储过程不一样(存储过程只是简单的存储SQL语句),触发器与单个的表相关联。

    22.4 数据库安全

    任何安全系统的基础都是用户授权和身份确认。

    一般说来,需要保护的操作有:

    • 对数据库管理功能(创建表、更改或删除已存在的表等)的访问;
    • 对特定数据库或表的访问;
    • 访问的类型(只读、对特定列的访问等);
    • 仅通过视图或存储过程对表进行访问;
    • 创建多层次的安全措施,从而允许多种基于登录的访问和控制;
    • 限制管理用户账号的能力。

    22.5 小结

    不同的DBMS可能会以不同的形式提供这些特性,更详细的信息请参阅具体的DBMS文档。

  • 相关阅读:
    Transfer-Encoding: chunked
    使用Kubeadm搭建Kubernetes集群
    连载二:Oracle迁移文章大全
    今晚直播:WLS/WAS故障基本分析介绍
    判断用户是否登录
    row_number() over (partition by a.sql_id order by a.id desc ) r
    Django admin添加用户
    从数据仓库到百万标签库,精细化数据管理,这么做就够了
    用 C 语言开发一门编程语言 — 更好的语言
    ubuntu下 全然卸载火狐浏览器
  • 原文地址:https://www.cnblogs.com/zhangsonghui/p/13375661.html
Copyright © 2020-2023  润新知