zoukankan      html  css  js  c++  java
  • 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关系型数据库 映射)

  • 相关阅读:
    Golang 实现简单的 Web 服务器
    Aliyun linux repo文件
    云服务器查看登录ip和本机出口ip
    10个高效Linux技巧及Vim命令对比
    使用mkfs.ext4格式化大容量磁盘
    LINUX SHELL 多个命令一起执行的几种方法
    GPT分区
    3种方法更改Linux系统的主机名(hostname)
    Nginx代理访问RDS
    Centos7安装Docker
  • 原文地址:https://www.cnblogs.com/xiarongjin/p/8371021.html
Copyright © 2011-2022 走看看