zoukankan      html  css  js  c++  java
  • MySQL中的完整性约束

    对于已经创建好的表,虽然字段的数据类型决定所能存储的数据类型,但是表中所存储的数据是否合法并没有检查。

    MySQL支持的完整性约束:

    • NOT NULL                    约束字段的值不能为空
    • DEFAULT                        设置字段的默认值
    • UNIQUE KEY(UK)             约束字段的值是唯一
    • PRIMARY KEY(PK)            约束字段为表的主键,可以作为该表记录的唯一标识
    • AUTO_INCREMENT           约束字段的值为自动增加
    • FOREIGN KEY(fk)             约束字段为表的外键

    设置表的非空约束

    非空性很好理解,就是设置表中字段的值不能为空(NULL)

    如果在已经设置此约束性条件的字段中插入空值,数据库系统则会报错。

    mysql> create table student4(
        -> id int not null,
        -> name varchar(20),
        -> sex boolean
        -> );

    用desc table或者show full columns from table可以看到关于表的描述。例如上面的表:

    mysql> desc student4;
    +-------+-------------+------+-----+---------+-------+
    | Field | Type        | Null | Key | Default | Extra |
    +-------+-------------+------+-----+---------+-------+
    | id    | int(11)     | NO   |     | NULL    |       |
    | name  | varchar(20) | YES  |     | NULL    |       |
    | sex   | tinyint(1)  | YES  |     | NULL    |       |
    +-------+-------------+------+-----+---------+-------+
    3 rows in set (0.00 sec)

    看到NULL那部分为NULL。


    设置表的唯一性约束

    唯一性是指表中该字段的值不能重复出现,设置表的唯一性约束

    也就是给表中某个字段加上unique

    mysql> create table student5(
        -> id int unique,
        -> name varchar(20)
        -> );
    Query OK, 0 rows affected (0.10 sec)

    此处id字段便不可重复。

    如果想给字段id的UK上设置一个名字,可以执行SQL语句CONSTRAINT,创建表的时候,具体SQL语句如下:

    mysql> create table student5(
        -> id int unique,
        -> name varchar(20),
        -> CONSTRAINT uk_id UNIQUE(id)
        -> );

    设置表的主键

    主键能够标识表中每条信息的唯一性,如同身份证号码和人的关系

    人可以同名,但是身份证号码却是唯一的,

    创建主键的目的在于快速查找到表中的某一条信息

    单字段主键
    mysql> create table student(
        -> id int primary key,
        -> name varchar(20),
        -> sex boolean
        -> );
    Query OK, 0 rows affected (0.09 sec)

    创建了三个字段,其中id为主键

    多字段主键

    多字段主键由多个属性组合而成,在属性定义完之后统一设置主键

    复制代码
    mysql> create table student2(
        -> id int,
        -> course_id int,
        -> score float,
        -> primary key(id,course_id)
        -> );
    Query OK, 0 rows affected (0.11 sec)
    复制代码

    student2表有三个字段,其中id和course_id的组合可以确定唯一的一条记录


    设置表的外键

    表的外键与主键是相对应的,比如表A中的id是外键,表B中的id是主键

    那么就可以称表B为父表,表A为子表

    设置表外键的作用在于建立与父表的联系,比如表B中id为123的学生删除后,表A中id为123的记录也随着消失

    这样做的目的在于保证表的完整性

    复制代码
    mysql> create table student3(
        -> id int primary key,
        -> course_id int,
        -> teacher varchar(20),
        -> constraint fk foreign key(id,course_id)
        -> references student2(id,course_id)
        -> );
    Query OK, 0 rows affected (0.12 sec)
    复制代码

    这里创建student3表,constraint后面的fk是外键别名,foreign key也就是设置外键的字段

    references后的内容表示父表,和父表中的主键

    需要注意的是,父表中的主键不能为空,并且主键和外键的数据类型要一致


    设置表的属性值自动增加

    auto_increment主要用于为表中插入的新记录自动生成唯一的ID

    一个表只能有一个字段使用auto_increment约束

    并且该字段必须为主键的一部分

    mysql> create table student6(
        -> id int primary key auto_increment,
        -> name varchar(20)
        -> );
    Query OK, 0 rows affected (0.12 sec)

    这里的id是主键,并且会自动增加id值,比如1,2,3,4……

    需要注意的是,auto_increment约束的值必须是整数类型


    设置表中属性的默认值

    在表中插入一条新的记录时,如果没有为该字段赋值

    那么数据库系统会自动为该字段赋上一条默认值

    mysql> create table student7(
        -> id int primary key,
        -> score int default 0
        -> );
    Query OK, 0 rows affected (0.10 sec)

    此处的score字段便会默认为0

  • 相关阅读:
    next()nextLine()以及nextInt()的区别及用法【转载】
    JAVA集合 list set map
    JAVA求回文数
    左移右移操作_进制转换与区分
    window_mysql踩坑
    centos_mysql踩坑
    【纪中受难记】——C3D6:大小不分
    zzLinux 中直接 I/O 机制的介绍https://www.ibm.com/developerworks/cn/linux/l-cn-directio/
    zz-zookeeper 启动失败 BindException: Address already in use 或者Error contacting service. It is probably not running
    zz---对象存储(Object-based Storage)概述
  • 原文地址:https://www.cnblogs.com/LUO77/p/5800896.html
Copyright © 2011-2022 走看看