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

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

 

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关系型数据库 映射)

以上是关于MySQL 完整性约束的主要内容,如果未能解决你的问题,请参考以下文章

一篇文章带你彻底了解MySQL各种约束

MySQL的约束

MySQL表的完整性约束

MySQL表的完整性约束

mysql表的完整性约束

Mysql 完整性约束