Database - QLGQ/learning-python GitHub Wiki

数据库中的键

  • 超键(super key):在关系中能唯一标识元组的属性集称为关系模式的超键。
  • 候选键(candidate key):不含有多余属性的超键称为候选键。
  • 主键(primary key):用户选作元组标识的一个候选键程序主键。
  • 外键(foreign key):如果关系模式R1中的某属性集不是R1的主键,而是另一个关系R2的主键则该属性集是关系模式R1的外键。

实例

假设有如下两个表:
学生(学号,姓名,性别,身份证号,教师编号)
教师(教师编号,姓名,工资)
超键:由超键的定义可知,学生表中含有学号或者身份证号的任意组合都为此表的超键。如:(学号)、(学号,姓名)、(身份证号,性别)等。
候选键:候选键属于超键,它是最小的超键,就是说如果再去掉候选键中的任何一个属性它就不再是超键了。学生表中的候选键为:(学号)、(身份证号)。
主键:主键就是候选键里面的一个,是人为规定的,例如学生表中,我们通常会让“学号”做主键,教师表中让“教师编号”做主键。
外键:外键比较简单,学生表中的外键就是“教师编号”。外键主要是用来描述两个表的关系。

键约束

主键约束

主键是每行的唯一标识符,仅仅通过它就能准确定位到一行,其中主键列在整个表中不能有重复,必须包含唯一的值(不能为NULL)。由于主键在关系数据库中的重要性,因此它是所有键和约束中最重要的。

  1. 在创建表的时候创建主键约束
create table customer
(
    customerId     int identity    not null    primary key
);
  1. 在已存在的表上创建主键约束
alter table person
    add constraint PK_Employee_Id  --主键名称
    primary key(personId)  --personId 字段名

alter名称告诉SQLServer如下信息:

  • 添加了一些内容到表中(也可以删除表中的某些内容)
  • 添加了什么内容(一个约束)
  • 对约束的命名(允许以后直接访问约束)
  • 约束的类型(主键约束)
  • 约束应用于哪个列

外键约束

外键既能确保数据完整性,也能表现表之间的关系。添加了外键之后,插入引用表的记录要么必须被引用列的某条记录匹配,要么外键列的值必须设置为NULL。外键和主键不一样,每个表中的外键数目不限制唯一性,唯一的限制是一个列只能引用一个外键,一个列可以被多个外键引用。

  • 创建表的时候创建外键
create table orders
(
    orderId        int identity    not null
        primary key,
    customerId    int                not null
        foreign key references customer(customerId)  --约束类型-外键-引用表(列名)
);
  • 在已存在的表中添加一个外键
alter table orders
    add constraint FK_Orders_CustomerId        --添加约束 名称
        foreign key (customerId)    references customer(customerId)    --外键约束,外键列名,被引用列名
  • 级联动作
    外键和其他类型键的一个重要区别是:外键是双向的,即不仅是限制子表的值必须存在于父表中,还在每次对父表操作后检查子行(这样避免了孤行)。SQLServer的默认行为是在子行存在时“限制”父行被删除。然而,有时会自动删除任何依赖的记录,而不是防止删除被引用的记录。同样在更新记录时,可能希望依赖的记录自动引用刚刚更新的记录。比较少见的情况是,你可能希望将引用行改变为某个已知的状态。为此,可以选择将依赖行的值设置为NULL或者那个列的默认值。这种进行自动删除和自动更新的过程称为级联。这种过程,特别是删除过程,可以经过几层的以来关系(一条记录依赖于另一条记录,而这另一条记录又依赖其他记录)。在SQLServer中实现级联动作需要做的就是修改外键语法-只需要在添加前面加上ON子句。例如:
alter table orders
    add constraint FK_Orders_CustomerId        --添加约束 名称
        foreign key (customerId)    references customer(customerId)    --外键约束,外键列名,被引用列名
        on update     no action    --默认  修改时不级联更新子表
        on delete     cascade      --删除时级联删除依赖行

当在进行级联删除时,如果一个表级联了另一个表,而另一个表又级联了其他表,这种级联会一直下去,不受限制,这其实是级联的一个危险之处,很容易一个不小心删掉大量数据。级联动作除了no action,cascade之外,还有set null和set default。后两个是在SQLServer2005中引入的,如果要兼容到SQLServer2000的话,要避免使用这两个级联动作。但是他们的才做是非常简单的:如果执行更新而改变了一个父行的值,那么子行的值将被设置为NULL,或者设置为该列的默认值(不管SET NULL还是SET DEFAULT)。

唯一约束

唯一约束与主键比较相似,共同点在于它们都要求表中指定的列(或者列的组合)上有一个唯一值,区别是唯一约束没有被看作表中记录的唯一标识符(即使你可以按这样的方式使用也有效),而且可以有多个唯一约束(而在每个表中只能有一个主键)。一旦建立了唯一约束,那么指定列中的每个值必须是唯一的。如果更新或者插入一条记录在带唯一约束的列上有已经存在的值的记录,SQLServer将抛出错误,拒绝这个记录。和主键不同,唯一约束不会自动防止设置一个NULL值,是否允许为NULL由表中相应列的NULL选项的设置决定,但即使确实允许NULL值,一张表中也只能够插入一个NULL值(如果允许多个,那就不叫唯一了)。
在已存在的表上创建唯一约束:

alter table Account
    add constraint AK_AccountName    --约束名
    unique (Account_Name)    -- 列名

AK代表替换键(Alternate Key),唯一约束也叫替换键。
主键和唯一约束的区别:

  • 主键约束不允许出现NULL值。任何索引的索引键都不允许包含null值。但唯一约束允许包含NULL值,但唯一约束把两个NULL值当作重复值,所以施加了唯一约束的每一列只允许包含一个NULL值。
  • 创建主键时会自动创建聚集索引,除非当前表中已经含有了聚集索引或是创建主键时指定了NONCLUSTERED关键字。
  • 创建唯一约束时会自动创建非聚集索引,除非你指定了CLUSTERED关键字并且当前表中还没有聚集索引。
  • 每个表中只能有一个主键,但可以由多个唯一约束。

CHECK约束

CHECK约束可以和一个列关联,也可以和一个表关联,因为它们可以检查一个列的值相对于另外一个列的值,只要这些列都在同一个表中以及值是在更新或者插入的同一行中。CHECK约束还可以用于检查列值组合是否满足某一个标准。可以像使用where子句一样的规则来定义CHECK约束。几乎所有可以放到where子句的条件都可以放到该约束中。而且和其他选择(规则和触发器)相比,CHECK约束执行速度更快。
在已存在的表中添加一个CHECK约束:

alter table Account
    add constraint CN_AccountAge
    check 
    (Account_Age > 18);    -- 插入年龄必须大于18

DEFAULT约束

和所有约束一样,DEFAULT约束也是表定义的一个组成部分,它定义了当插入的新行对于定义了默认约束的列未提供相应数据时该怎么办。可以定义它为一个字面值(例如,设置默认薪水为0,或者设置字符串列为"UNKNOWN"),或者某个系统值(getdate())。对于DEFAULT约束,要了解以下几个特性:

  1. 默认值只在insert语句中使用-在update语句和delete语句中被忽略。
  2. 如果在insert语句中提供了任意值,那就不使用默认值。
  3. 如果没有提供值,那么总是使用默认值。

值得注意的是,update命令的规则由一个例外,如果显示说明使用默认值就是例外。可以通过使用关键字DEFAULT表示更新的值设置为默认值。

  • 在创建表时定义DEFAULT约束:
create table person
(
    person_id int identity not null
        primary key,
    person_name nvarchar(30) not null
        default '无名氏',
    person_age int not null
)
  • 在已存在的表上添加DEFAULT约束:
alter table person
    add constraint CN_DefaultName
    default    '无名氏' for person_name

SQL数据库入门基础

SQL(Structure Query Language,结构化查询语言)语言是国际标准化组织(ISO)采纳的标准数据库语言。
SQL数据库

SQL语言分类

SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML, 数据定义语言DDL,数据控制语言DCL。

数据查询语言DQL(Data Query Language)

数据查询语言DQL用于检索数据库,基本结构是由SELECT子句,FROM子句,WHERE子句组成的查询块:Select <字段名表> From <表或视图名> Where <查询条件>

数据操纵语言DML(Data Manipulation Language)

(SELECT,DELETE,UPDATE,INSERT) 数据操纵语言DML用于改变数据库数据,主要有三种形式:

  1. 插入:Insert
  2. 更新:Update
  3. 删除:Delete

数据定义语言DDL(Data Definition Language)

(CREATE,ALTER,DROP,DECLARE)数据定义语言DDL用于建立,修改,删除数据库中的各种对象-----表、视图、索引、同义词、聚簇等如:CREATE TABLE/VIEW/INDEX/SYN/CLUSTER。

数据控制语言DCL(Data Control Language)

(GRANT,REVOKE,COMMIT,ROLLBACK)数据控制语言DCL用来授予或回收访问数据库的某种特权,并控制数据库操纵事务发生的时间及效果,对数据库实行监视等。包括两条命令:

  1. Grant:授权
  2. Revoke:撤回

Reference

SQLServer-约束

⚠️ **GitHub.com Fallback** ⚠️