问题描述
我的表之间有以下关系:
CREATE TABLE `class` (
`id` int(0) NOT NULL,`grade` varchar(255) NOT NULL COMMENT 'first,second,etc (grade)',`province` varchar(255) NOT NULL,PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB ROW_FORMAT = Dynamic;
CREATE TABLE `class_province` (
`id` int(0) NOT NULL,`class` int(0) NOT NULL,`province` int(0) NOT NULL,PRIMARY KEY (`id`) USING BTREE,INDEX `fk_nm_class`(`class`) USING BTREE,INDEX `fk_nm_province`(`province`) USING BTREE,CONSTRAINT `fk_nm_class` FOREIGN KEY (`class`) REFERENCES `class` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,CONSTRAINT `fk_nm_province` FOREIGN KEY (`province`) REFERENCES `province` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
) ENGINE = InnoDB ROW_FORMAT = Dynamic;
CREATE TABLE `class_schooltype` (
`id` int(0) NOT NULL,`schooltype` int(0) NOT NULL,INDEX `fk_nm_schooltype`(`class`) USING BTREE,CONSTRAINT `fk_nm_classschooltype` FOREIGN KEY (`class`) REFERENCES `class` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,CONSTRAINT `fk_nm_schooltype` FOREIGN KEY (`class`) REFERENCES `school_type` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
) ENGINE = InnoDB ROW_FORMAT = Dynamic;
CREATE TABLE `country` (
`id` int(0) NOT NULL,`name` varchar(255) NOT NULL,PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB ROW_FORMAT = Dynamic;
CREATE TABLE `province` (
`id` int(0) NOT NULL,`country` int(0) NOT NULL,INDEX `fk_province_country`(`country`) USING BTREE,CONSTRAINT `fk_province_country` FOREIGN KEY (`country`) REFERENCES `country` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
) ENGINE = InnoDB ROW_FORMAT = Dynamic;
CREATE TABLE `school_type` (
`id` int(0) NOT NULL,INDEX `fk_schooltype_country`(`country`) USING BTREE,CONSTRAINT `fk_schooltype_country` FOREIGN KEY (`country`) REFERENCES `country` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
) ENGINE = InnoDB ROW_FORMAT = Dynamic;
我的问题是现在班级可以有一个省(有A国)和一个可以有B国的学校类型。这应该是不可能的。 我可以改变什么? 提前致谢!
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)