我正在使用phpMyAdmin设置数据库。我有两个表(foo和bar),在它们的主键上建立索引。我试图在它们之间创建一个关系表(foo_bar),使用它们的主键作为外键。
我用MyISAM创建了这些表,但后来把三个表都换成了InnoDB,因为我读到MyISAM不支持外键。所有id字段都是INT(11)。
当我选择foo_bar表时,单击“关系视图”链接,并尝试将FK列设置为database.foo.id和database.bar。id,它会在每一列旁边说“未定义索引!”
我错过了什么?
澄清/更新
为了简单起见,我想继续使用phpMyAdmin。我目前使用XAMPP,这很容易让我专注于PHP/CSS/Javascript,它附带phpMyAdmin。
此外,虽然我还不能设置显式外键,我有一个关系表,可以执行这样的连接:
SELECT *
FROM foo
INNER JOIN foo_bar
ON foo.id = foo_bar.foo_id
INNER JOIN bar
ON foo_bar.bar_id = bar.id;
在数据库中没有显式定义fk只是让我感到不舒服。
对于那些刚接触数据库....的人并且需要ALTER一个现有的表。很多事情看起来都很简单,但总有一些……在A和B之间。
在做其他事情之前,先看看这个。
Make sure you have P_ID (parent ID on both parent and child table).
Of course it will be already filled in the parent. Not necessarily in the child in a true and final way. So for instance P_ID #3 (maybe many times in the child table will be pointing to original P_ID at parent table).
Go to SQL tab (I am using phpMyAdmin, should be similar in other ones) and do this command:
ALTER TABLE child_table_name
ADD FOREIGN KEY (P_ID)
REFERENCES parent_table_name (P_ID)
Click on child table, than structure, finally on relational view. Finish your DB planning there. There was a nice answer before this one about cascade, restrict, etc.
Of course it could be done by commands...
这是一个老帖子,但回答,因为如果对任何人都有用。
步骤1。您的Db存储引擎设置为InnoDB
步骤2。创建主表
这里customer是主表,customer_id是主键
步骤3。创建外键表并给出索引
这里我们有customer_addresses作为相关表和存储客户地址,所以这里customer_id与客户表的关系
创建表时可以直接选择索引
如果你在创建表时忘记了索引,那么你可以从表的结构选项卡中给出索引,如下所示。
步骤4。一旦索引给出字段,去结构选项卡,并点击关系视图,如下图所示
第5步。现在选择ON DELETE和ON UPDATE你想做的,从当前表中选择列,选择DB (SAME DB),从该表中选择关系表和主键,如下图所示,并保存它
现在检查关系是否成功给出,转到外表数据列表并单击外键值,您将重定向到主表记录,然后关系创建成功。
确保你的mysql存储引擎是Innodb而不是MYISAM,因为Innodb存储引擎支持mysql中的外键。
在phpmyadmin创建外键的步骤:
轻按结构表将有外键。
为要用作外键的列创建INDEX。
点击位于表结构下面的关系视图
在Relation视图页面中,您可以在字段(被创建为INDEX)前面看到选择选项。
UPDATE CASCADE指定当被引用的列被更新时,该列也将被更新。
DELETE CASCADE指定的行将在删除被引用的行时被删除。
或者,您也可以触发相同的sql查询
ALTER TABLE table_name
ADD CONSTRAINT fk_foreign_key_name
FOREIGN KEY (foreign_key_name)
REFERENCES target_table(target_key_name);