- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
当我执行此脚本创建 2 个表时,其中 CUSTOMER 表中的 STORE 列引用 USERS 表中的 ID 列(两列均为 INT):
SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL,ALLOW_INVALID_DATES';
CREATE SCHEMA IF NOT EXISTS `part_finder` DEFAULT CHARACTER SET utf8 ;
USE `part_finder` ;
-- -----------------------------------------------------
-- Table `part_finder`.`users`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `part_finder`.`users` (
`id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`account` MEDIUMINT(7) UNSIGNED NOT NULL COMMENT 'Account organisation user belongs to',
`name` VARCHAR(32) NULL DEFAULT NULL,
`passenc` VARCHAR(32) NULL DEFAULT NULL,
`email` VARCHAR(55) NULL DEFAULT NULL,
`rank` DECIMAL(1,0) NULL DEFAULT '0',
`ip_reg` VARCHAR(15) NULL DEFAULT NULL,
`ip_visit` VARCHAR(15) NULL DEFAULT NULL,
`dtreg` INT(11) NOT NULL,
`dtvisit` INT(11) NOT NULL,
`visits` SMALLINT(5) UNSIGNED NULL DEFAULT '0',
`pass` VARCHAR(25) NULL DEFAULT NULL,
`make_filter_on` TINYINT(1) NULL DEFAULT FALSE,
`brand_filter_on` TINYINT(1) NULL DEFAULT FALSE,
PRIMARY KEY (`id`))
ENGINE = InnoDB
AUTO_INCREMENT = 3;
-- -----------------------------------------------------
-- Table `part_finder`.`customer`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `part_finder`.`customer` (
`id` INT UNSIGNED NOT NULL AUTO_INCREMENT,
`store` INT(10) NOT NULL,
`name` VARCHAR(32) NULL,
`address` VARCHAR(45) NULL,
`address_2` VARCHAR(45) NULL,
`city` VARCHAR(15) NULL,
`state` TINYINT UNSIGNED NOT NULL,
`zip` CHAR(5) NULL,
`phone` VARCHAR(15) NULL,
`website` VARCHAR(45) NULL,
`email` VARCHAR(55) NULL,
PRIMARY KEY (`id`),
INDEX `fk_customer_users_idx` (`store` ASC),
CONSTRAINT `fk_customer_users`
FOREIGN KEY (`store`)
REFERENCES `part_finder`.`users` (`id`)
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB;
SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;
我收到这个错误:
ERROR: Error 1215: Cannot add foreign key constraint
-- -----------------------------------------------------
-- Table `part_finder`.`customer`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `part_finder`.`customer` (
`id` INT UNSIGNED NOT NULL AUTO_INCREMENT,
`store` INT(10) NOT NULL,
`name` VARCHAR(32) NULL,
`address` VARCHAR(45) NULL,
`address_2` VARCHAR(45) NULL,
`city` VARCHAR(15) NULL,
`state` TINYINT UNSIGNED NOT NULL,
`zip` CHAR(5) NULL,
`phone` VARCHAR(15) NULL,
`website` VARCHAR(45) NULL,
`email` VARCHAR(55) NULL,
PRIMARY KEY (`id`),
INDEX `fk_customer_users_idx` (`store` ASC),
CONSTRAINT `fk_customer_users`
FOREIGN KEY (`store`)
REFERENCES `part_finder`.`users` (`id`)
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB
SQL script execution finished: statements: 6 succeeded, 1 failed
Fetching back view definitions in final form.
Nothing to fetch
我使用的是 InnoDB,我已经检查了我的外键列的数据类型,并确保我使用的是引用表中的主键。
有什么想法吗?
最佳答案
也许父表中的列是 INT UNSIGNED
?
它们在两个表中的数据类型必须完全相同。
可能出现外键约束错误的原因:
您正在尝试引用目标表中不存在的键。确保它是另一个表上的键(它可以是主键或唯一键
),
列的类型不一样(除了列在引用表上可以是 nullable
)。
关于MySQL Workbench 正向工程师错误 1215 : Cannot add foreign key constraint,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22904930/
I have a question about adding files in git. I have found multiple stackoverflow questions about
我是 visual studio 的新手,来自 Delphi。 我有一个充满 .cs 文件的目录树(根是\Common)。 我还有一个充满应用程序的目录树(根目录是\Applications) 最后,
这个问题在这里已经有了答案: Array's lookup time complexity vs. how it is stored (4 个答案) Time complexity for java
谁能告诉我这两者有什么区别: ALTER TABLE x1 ADD INDEX(a); ALTER TABLE x1 ADD INDEX(b); 和 ALTER TABLE x1 ADD INDEX(
为什么有时我们使用 getChildren() add() 而其他时候我们直接使用 add() es: https://docs.oracle.com/javafx/2/get_started/for
如何使用 bootstrap css 在输入下方添加跨度?我需要做这样的事情: 最佳答案 是这样的吗? http://jsfiddle.net/swm53ran/205/ 您可以使用纯 CSS 来实现
问题 np.add(X, 2*Y, out=X) 比 np.add(X, Y, out=X); np.add(X, Y, out=X).使用 np.add(X, Y, out=X); 是一种实际做法吗
当我跑 git add --intent-to-add .所有未跟踪的文件将其状态从“未跟踪的文件”( git status -s 显示 ?? )更改为“未暂存以进行提交的更改”( git statu
我不知道 .add 之间有什么区别和 .sink.add ? 例子: StreamController myStreamController = StreamController(); stream
getContentPane().add() 和 add() 的意思一样吗? public class TestFrame extends JFrame{ public TestFrame()
git add . 和 git add * 会完成完全相同的事情吗? 最佳答案 不,不会。 * 是一个 glob 模式,不会匹配以 开头的文件。 例如,假设这是当前目录,我有 2 个新文件要添加 fo
git的分支与合并的两种方法 git add -A和 git add . git add -u在功能上看似很相近,但还是存在一点差别 git add . :他会
git add [--all | -A] 之间有什么区别?和 git add . ? 最佳答案 此答案仅适用于 Git 版本 1.x。对于 Git 版本 2.x,请参阅其他答案。 总结: git ad
我刚刚安装了最新的 Wix v3.7。我创建了一个 VS 2010“Excel 2010 加载项”项目,并在同一个解决方案中创建了一个 Wix“安装项目”。 问题是,当我尝试从 Wix 项目中引用 A
YUI.add 和 YUI().add 有什么区别? 最佳答案 在第一种情况下,您要注册一个模块可以加载到 YUI 沙箱中,在第二种情况下,您要构建一个沙箱,然后进行注册(这是一种非常不典型的用法)。
测试代码时,任何输入到列表中的值在按下“enter”后都会消失。 我对编程和网络开发非常陌生。请具体一点,以便我理解。 function addItem(){ var item = documen
我正在浏览 python 的 dis 包。我尝试了代码以查看它是如何工作的 >>> def get(): ... x=4 ... y=x+3 ............ this lin
我已经对我的文件夹进行了版本控制 git init git add . git commit -m 'Initial commit' 我应该怎么做 git add 对于我在 .? 中创建的每个新文件
当我执行 $ git add * 时,有时我意识到 git 不会将已删除的文件添加到舞台上,如果删除或添加它,我需要手动指示,但我想不通找出 $ git add --all 有什么区别。因此,如果星号
这个问题在这里已经有了答案: Difference between "git add -A" and "git add ." (12 个答案) 关闭 6 年前。 目前,当我想提交并将内容推送到远程
我是一名优秀的程序员,十分优秀!