码迷,mamicode.com
首页 > 数据库 > 详细

MySQL 完整性约束

时间:2018-01-28 14:42:41      阅读:193      评论:0      收藏:0      [点我收藏+]

标签:log   prim   user   类型   通过   gen   修改   bat   逻辑   

完整性约束

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

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 完整性约束

标签:log   prim   user   类型   通过   gen   修改   bat   逻辑   

原文地址:https://www.cnblogs.com/xiarongjin/p/8371021.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!