0

我正在为 mysql 使用 phpmyadmin。我有 4 个表 project1、project2、project3 和组合表。假设 combine 表使用外键连接到所有其他表,并且我们在一些后台脚本的帮助下将一些数据添加到 project1、prject2 和 project3 表。有什么方法可以自动更新组合表中的相应外键(无需手动更新记录)。我正在为 GUI 使用 yii 框架。请提出一些建议,因为我是 mysql 和 yii 框架的新手。

4

1 回答 1

0

http://dev.mysql.com/doc/refman/5.6/en/create-table-foreign-keys.html

不完全理解您的问题,但我认为您指的是ON DELETEand ON UPDATE

ON DELETE&ON UPDATE选项

CASCADE
SET NULL
NO ACTION
RESTRICT

ON DELETE & ON CASCADE 作为约束放置在 FK 表中,并且在删除或更新父 ID 时发生。

因此,如果您更改项目表中的 id 并且希望此更改反映在组合表中,您将使用ON UPDATE CASCADE.

作为旁注,为什么你有 4 张桌子?我只能看到需要 2 张桌子。

请注意,下面的 SQL 在语法上可能不正确。

CREATE TABLE tbl_projects (
  id integer NOT NULL PRIMARY KEY AUTO INCREMENT,
  name varchar(255),
  ...
  ...
);

方法1为组合表中的每个项目创建一行:

CREATE TABLE tbl_combine (
  id integer NOT NULL PRIMARY KEY AUTO INCREMENT,
  project_id integer,
  ...
  CONSTRAINT `FK_combine_project` 
      FOREIGN KEY (`project_id`) 
      REFERENCES `tbl_project` (`id`)
      ON DELETE CASCADE ON UPDATE CASCADE
);

方法二:

CREATE TABLE tbl_combine (
  id integer NOT NULL PRIMARY KEY AUTO INCREMENT,
  project1_id integer,
  project2_id integer,
  project3_id integer,
  ...
  CONSTRAINT `FK_combine_project1` 
      FOREIGN KEY (`project1_id`) 
      REFERENCES `tbl_project` (`id`)
      ON DELETE CASCADE ON UPDATE CASCADE

  CONSTRAINT `FK_combine_project2` 
      FOREIGN KEY (`project2_id`) 
      REFERENCES `tbl_project` (`id`)
      ON DELETE CASCADE ON UPDATE CASCADE

  CONSTRAINT `FK_combine_project3` 
      FOREIGN KEY (`project3_id`) 
      REFERENCES `tbl_project` (`id`)
      ON DELETE CASCADE ON UPDATE CASCADE
);

您也可以通过 phpmyadmin 中的 GUI 执行此操作,方法是通过单击按钮将外键设置为索引,然后转到表关系视图并选择您的选项。

希望这会有所帮助 - 我附上了一张 phpmyadmin 图片供您查看。

PHP My ADMIN 外键约束

于 2013-07-11T13:42:00.353 回答