一个是让数据库自己通过外键来保证数据的完整性和一致性
一个就是能够增加ER图的可读性
2.外键的配置
1)先创建一个主表,代码如下:
#创建表student,并添加各种约束
create table student
(
id int primary key , #主键约束
name varchar(20) , #唯一约束
age int NOT NULL, #非空约束
sex varchar(2) ,
address varchar(20) default '重庆' #默认约束
)
再通过一个外键,创建一个分数表,这样的话,就可以方便查询。代码如下:
#创建分数表
create table score
(
id int primary key ,
sid int ,
china int ,
history int,
english int,
constraint FK_sid foreign key(sid) references student(id) #通过外键创建链接
)
创建外键的方法有很多,其中最常见创建外键的格式是:constraint FK_*** foreign key(**) references 链接的外表
删除外键:
alter table drop foreign key '外键名'.
注意:
只有在定义外键时,用constraint 外键名 foreign key .... 方便进行外键的删除
主键是唯一标示这一行的,就好像你的身份z号一样,每个人只有一个,也是唯一能证明你是你的东西。外键是别人执行你的东西。也就是说如果一个人想和你有点关系怎么办,那就要关联起来,怎么关联起来,就通过外键啊
定义主键和外键主要是为了维护关系数据库的完整性,总结一下:
一、主键是能确定一条记录的唯一标识,比如,一条记录包括身份正号,姓名,年龄。身份z号是唯一能确定你这个人的,其他都可能有重复,所以,身份z号是主键。
外键用于与另一张表的关联。是能确定另一张表记录的字段,用于保持数据的一致性。比如,A表中的一个字段,是B表的主键,那他就可以是A表的外键。
我遇到的原因:由于我的 tb_article 表的category_id设置为 not null ,并且 tb_category 的主键 id 也为 not null ,但是我的的 tb_article 表中的一行数据中, category_id 为 null ,所以就创建失败了把 category_id 字段填写好,就OK了
你的 tb_aryicle 的 category_id 字段的设置,和 tb_category 的 id 字段的设置不一样,一定要保证他们 datatype 和一些属性(如: not null 等)一致。
这也是之前遇到过的问题,这里记录一下
我遇到的原因:当前数据表和引用表的对应字段属性不一样(疏忽大意)
把当前数据表的 category_id 字段改成varchar类型就好了
1.添加外键报错,外键无法建立无非这几种可能(一)确定外键上建立了索引,否则无法创建约束;
(二) 外键的引用类型和主表列类型不一致,比如主键是number的,外键是varchar2的;
(三)确定引用的主表列存在;
2.建表报错上提示此表已存在哦,drop之后再建表。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)