博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL 完整性约束
阅读量:5065 次
发布时间:2019-06-12

本文共 994 字,大约阅读时间需要 3 分钟。

完整性约束

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

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

转载于:https://www.cnblogs.com/xiarongjin/p/8371021.html

你可能感兴趣的文章
Recipe 1.4. Reversing a String by Words or Characters
查看>>
Rule 1: Make Fewer HTTP Requests(Chapter 1 of High performance Web Sites)
查看>>
sql注入
查看>>
「破解」Xposed强
查看>>
src与href的区别
查看>>
ABAP工作区,内表,标题行的定义和区别
查看>>
《xxx重大需求征集系统的》可用性和可修改性战术分析
查看>>
Python 中 创建类方法为什么要加self
查看>>
关于indexOf的使用
查看>>
【转】JS生成 UUID的四种方法
查看>>
英语单词
查看>>
centos6.8下安装matlab2009(图片转帖)
查看>>
Mongo自动备份
查看>>
求助大神!怎样批量删除数据库表中某个字段中同样的一段字符!
查看>>
VMWARE虚拟机无法访问的三种方法分析
查看>>
enq: SQ - contention
查看>>
cer证书签名验证
查看>>
ant 安装
查看>>
新手Python第一天(接触)
查看>>
vue路由动态加载
查看>>