MySQL 完整性约束
Posted 学海无涯
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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
业务主键:还有一定的业务意义。
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关系型数据库 映射)
以上是关于MySQL 完整性约束的主要内容,如果未能解决你的问题,请参考以下文章