最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL外键创建失败的解决

来源:动视网 责编:小采 时间:2020-11-09 11:23:39
文档

MySQL外键创建失败的解决

MySQL外键创建失败的解决:创建persons:CREATE TABLE `persons` ( `id_p` int(11) NOT NULL AUTO_INCREMENT, `lastname` varchar(10) DEFAULT NULL, `fi 创建persons:CREATE TABLE `persons` ( `id_p` int(11) NOT NULL A
推荐度:
导读MySQL外键创建失败的解决:创建persons:CREATE TABLE `persons` ( `id_p` int(11) NOT NULL AUTO_INCREMENT, `lastname` varchar(10) DEFAULT NULL, `fi 创建persons:CREATE TABLE `persons` ( `id_p` int(11) NOT NULL A


创建persons:CREATE TABLE `persons` ( `id_p` int(11) NOT NULL AUTO_INCREMENT, `lastname` varchar(10) DEFAULT NULL, `fi

创建persons:
CREATE TABLE `persons` (
`id_p` int(11) NOT NULL AUTO_INCREMENT,
`lastname` varchar(10) DEFAULT NULL,
`firstname` varchar(10) DEFAULT NULL,
`address` varchar(50) DEFAULT NULL,
`city` varchar(10) DEFAULT NULL,
PRIMARY KEY (`id_p`)
);

再创建表orders:
CREATE TABLE `orders` (
`id_o` int(11) NOT NULL AUTO_INCREMENT,
`orderno` int(11) NOT NULL,
`id_p` int(11) NOT NULL,
PRIMARY KEY (`id_o`),
FOREIGN KEY (`id_p`) REFERENCES `persons` (`id_p`)
);


用show create table orders语句,查询orders的信息发现,外键并没有创建成功。查了一些资料,,终于找到了原因。mysql默认创建的表是MyISAM类型的,需要将表的类型指定为innodb:


CREATE TABLE `orders` (
`id_o` int(11) NOT NULL AUTO_INCREMENT,
`orderno` int(11) NOT NULL,
`id_p` int(11) NOT NULL,
PRIMARY KEY (`id_o`),
FOREIGN KEY (`id_p`) REFERENCES `persons` (`id_p`)
) ENGINE=InnoDB;


不过这时提示以下错误:
ERROR 1005 (HY000): Can't create table 'test.orders' (errno: 150)
将persons表的类型也指定为innodb就OK了。

总结一下外键创建失败的几种情况:
1.外键和被引用外键类型不一样,比如integer和double
2.找不到要被引用的列
3.表的字符编码不一样
4.数据引擎类型不一致,比如innodb和myisam

文档

MySQL外键创建失败的解决

MySQL外键创建失败的解决:创建persons:CREATE TABLE `persons` ( `id_p` int(11) NOT NULL AUTO_INCREMENT, `lastname` varchar(10) DEFAULT NULL, `fi 创建persons:CREATE TABLE `persons` ( `id_p` int(11) NOT NULL A
推荐度:
标签: 创建 失败 解决
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top