• MySQL 完整性约束


    完整性约束

    数据完整性是为了保证插入到数据中的数据是正确的,它防止了用户可能的输入错误。

    2.1实体(记录)完整性

    规定表的一行(即每一条记录)在表中是唯一的实体(Entity)。实体完整性通过表的主键来实现。

    主键:不能为null;唯一

    创建一个表格T1,并声明一个主键

    写法一:(只能指定一个字段作为主键)

    create table T1(

    ID int primary key,

    NAME varchar(100)

    );

    写法二:(指定联合主键)

    create table T2(

    ID int,

    NAME varchar(100),

    primary key(ID)

    );

     

    写法三:(创建没有任何约束的表格,最后修改约束)建议

    create table T3(

    ID int,

    NAME varchar(100)

    );

    alter table T3 add primary key(ID);

    注意:

    逻辑主键(建议):除了唯一标识一条记录外,没有别的意义。一般取名ID

    业务主键:还有一定的业务意义。

    MySQL:

    create table T4(

    ID int primary key auto_increment,#自动增长,不建议使用。数据库迁移不方便,并不是所有的数据库都支持自动增长,比如Oracle就不支持。

    NAME varchar(100)

    );

    2.2域(字段)完整性

    指数据库表的列(即字段)必须符合某种特定的数据类型或约束

    1、约束数据的类型:强类型

    2、非空约束:not null

    3、唯一约束:unique

    create table T5(

    ID int primary key auto_increment,

    USERNAME varchar(100) not null unique,

    PHONE_NUM varchar(11) unique,

    GENDER varchar(10) not null

    );

    2.3参照完整性(多表的设计):定义外键

    注意:类和表结构的关系;对象和记录的关系(帮助学习ORM:Hibernate、MyBatis)

    ORM:Object Relation Mapping(Java面向对象 DB关系型数据库 映射)

  • 相关阅读:
    maven项目报错:Class path contains multiple SLF4J bindings
    ubuntu18.04 点击启动器实现窗口最小化
    Eclipse lombok get set方法报错
    try-with-resources 让java资源关闭代码更简洁
    yang文件语法格式
    RabbitMQ 交换器、持久化
    RabbitMQ 简介
    systemctl命令配置系统服务
    Karaf基础知识
    Linux shell模拟多线程拷贝
  • 原文地址:https://www.cnblogs.com/xiarongjin/p/8371021.html
Copyright © 2020-2023  润新知