约束是为了使表中的数据有效。常见的约束有:非空约束(not null)、唯一性约束(unique)、主键约束(primary key,简称PK)、外键约束(foreign key,简称FK)、检查约束(oracle中才可用)。

一,非空约束

        约束的字段不能为NULL。可以直接在创表时加上not null:

create table student (age int,name varchar(4) not null);

创建表后插入数据,如果是没有定义name只定义了年龄,那么不会有这行数据插入。相反,如果定义了name而没有age,数据可以成功插入,age为NULL。

Notations:可以将所有的sql语句写到一个.sql脚本文件中,然后source 路径运行脚本文件,相当于运行了所有的sql语句。

二,唯一性约束

        uniqe约束的字段不能重复,但是可以为NULL。如果重复保错:Duplicate entry xxx for key xxx。使用:直接在创表时在字段后加上unique。

联合唯一性:指两个字段联合起来具有唯一性(不是每个字段后面加unique,那是每个字段都唯一)。创表方式:

create table user(id int,name varchar(10),unique(id,name));

这种约束叫做表级约束。

Notations:

(1)not null 没有表级约束

(2)not null 和unique联合使用:直接在建表的时候在字段后同时加上not null 和unique。在mysql中,如果一个字段同时被这两个修饰,自动变成主键字段(在oracle中不是这样)。

三、主键约束

        主键约束中有:1,主键字段:该字段上有主键约束;2,主键值:主键字段的字面值。主键的定义:每一行记录的唯一标识。

Notations:主键值相当于一行记录的身份证号。每张表都应该有主键,没有主键该表无效。两行记录可能数据一样,但主键不同就是不同的记录。

        主键的特征:not null+unique(不能为空,不能重复)。

添加主键约束:

create table user(id int primary key,name varchar(255));

或者:

create table user(id int,name varchar(255),primary key(id));

复合主键(开发中不建议使用):

create table user(id int,name varchar(255),primary key(id,name));

主键只能在一张表中有一个。建议添加成主键的类型:int,char。不建议使用varchar这种变长的。

3.1 自然主键

主键是一个自然数,和业务没关系。

3.2 业务主键

主键和业务相关。如:银行卡账号

Notations:

(1)自然主键用的较多,因为其不受业务变化影响。

(2)auto_increment自动维护主键:

        create table user (id int unsigned primary key auto_increment,

                                        name varchar(255));

        会自动生成从1递增的主键id。

四,外键约束

        相关术语:外键字段,外键值。

如上表格,数据冗余度较高。可以把classno,classname存入一张班级表,把no,name存入另一张学生表,节省了空间,但是两张表没有关系。那么可以将classno加入到学生表中,但是在学生表中classno没有约束的话,可能会出错。为了保证classno中的值都是100或101,需要给其添加外键约束,classno就是外键字段。

给classno添加约束,让它去引用班级表中的classno字段。被引的班级表就称为父表。要注意它和子表学生表的顺序:

删除表:先删子表,再删父表;

创建表:先创父表,再创子表;

删除数据:先删子,再删父;

插入数据:先插父,再插子;

外键使用举例:
        create table class (
        class_no int primary key,
        class_name varchar(255));
        create table student(
        no int unsigned auto_increment,
        name varchar(255),
        class int,
        primary key(no),
        foreign key(class) references class(class_no);

添加了外键约束后,student中的class只能为class表中的class_no的值,不能是其他值。

Notations:

(1)父表中被引用的字段至少得有唯一性(unique)。

(2)外键值可以为NULL。

约束(constraint)相关推荐

  1. 创建和使用约束Constraint

    约束(Constraint)是Microsoft SQL Server 提供的自动保持数据库完整性的一种方法,定义了可输入表或表的单个列中的数据的限制条件(有关数据完整性的介绍请参见第9 章).在SQ ...

  2. SQL基础--gt; 约束(CONSTRAINT)

    --============================= --SQL基础--> 约束(CONSTRAINT) --============================= 一.几类数据完 ...

  3. 数据库 约束(Constraint)、多表关系和范式

    文章目录 约束 Constraint 分类 多表关系 范式 第一范式1NF. 第二范式2NF 第三范式3NF BCNF 约束 Constraint 概念: 对表中数据进行限制,保证数据正确性.有效性. ...

  4. [MySQL]约束(constraint)

    文章目录 1. 约束 1.1 数据的完整性 1.2 约束 1.3 约束的分类 2. 查看表中的约束 3. 非空约束(NOT NULL) 3.1 作用 3.2 特点 3.3 添加非空约束 3.3.1 建 ...

  5. 默认约束 oracle,ORACLE约束(constraint):对象的强制规定

    ORACLE约束(constraint):对象的强制规定 5种约束: NOT NULL     非空 NN UNIQUE       唯一 UK PRIMARY KEY  主键 PK FOREIGN ...

  6. MySQL 约束(Constraint)

    一.约束的概述 1.为什么要有约束? 为了保证数据的完整性 数据完整性(Date Integrity)是指数据的精确性(Accuracy)和可靠性(Reliability).它是防止数据库中存在不符合 ...

  7. System Verilog的约束constraint

    System Verilog的约束constraint 1.约束块(constraint block) 2.约束块的取值 A.简单表达式 B.约束块权重取值:dist 1.:=取权重 2.:/取权重 ...

  8. MYSQL_使用外键约束(constraint)或触发器(trigger)来进行级联更新、删除

    我们通常有这样的需求:删除表Table 1中记录,需要同时删除其它表中与Table 1有关的若干记录. 举个例子: 现有2个实体- 麻将机 学生.课程,1种联系- 成绩 分别创建 学生表 studen ...

  9. Oracle 约束 Constraint

    约束简介 约束用于确保数据库数据满足特定的商业逻辑或者企业规则,如果定义了约束,并且数据不符 合约束,那么DML操作(INSERT.UPDATE.DELETE)将不能成功执行.约束包括NOT NULL ...

  10. oracle建表6大约束,oracle 建表 约束 constraint

    约束命名规则 如果不指定约束名Oracle server 自动按照SYS_Cn 的格式指定约束名,也可手动指定, 推荐的约束命名是:约束类型_表名_列名. NN:NOT NULL           ...

最新文章

  1. 【C++】algorithm具体操作记录
  2. Android开发实战三之导入现有Android工程项目
  3. Yahoo前端优化性能规则
  4. 十种常用编程语言特点
  5. 初学者学习java编程,如何顺利通过4大艰难阶段?
  6. 映射文件_Hibernate 映射文件
  7. .NEt中的继承、聚合和组合
  8. 天天在做图表,其实你根本不懂数据可视化
  9. 放心!没人在意你使用的是命令式编程还是声明式编程
  10. ActionSheet的用法
  11. Rhel6-piranha配置文档
  12. Python基础学习1---函数
  13. 李宏毅机器学习笔记day1
  14. USBCAN 、便携式 CAN 分析仪 、CAN卡
  15. 如何使用远程控制软件并将用途最大化?4款国内外优质应用测评解析
  16. Spring AOP动态代理的两种实现方式
  17. 蓝色音箱改装电源_JBL便携/无线音箱排行榜,JBL便携/无线音箱十大排名推荐
  18. 奋斗的青春,无悔的时光
  19. golang基础教程
  20. matter设备调试(Device Commissioning):

热门文章

  1. 手把手教你在Windows下使用MinGW编译libav
  2. 基于docker使用GoAccess分析nginx日志
  3. 发现我们电脑中存储的wifi
  4. 浅谈在游戏陪玩开发中常见的几种加密算法及实现
  5. Java8的伪共享和缓存行填充--@Contended注释
  6. Python学习目录
  7. 10.华为WLAN产品介绍_华为WLAN产品应用
  8. 大疆SDK-航线文件
  9. python学习笔记05 字典dic增删查改常用操作及嵌套
  10. 值得学习的技术人——阮一峰