我正在尝试在Wordpress中制作3个数据库表
其中一个我希望与另一个有关系。但我无法找到如何在wordpress中制作引用键和内容。
使用此代码我在表上创建..但是如何使引用和键导致1个表将包含两个表之间的关系。
global $wpdb;
$table_name = $wpdb -> prefix . "Person";
if($wpdb ->get_var("SHOW TABELS LIKE '$table_name'") != $table_name)
{
$sql = "CREATE TABLE " . $table_name . " (
`id` INTEGER(9) NOT NULL AUTO_INCREMENT,
`titel` varchar(255) NOT NULL,
`content` text NOT NULL,
UNIQUE KEY id (id)
);";
require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
dbDelta($sql);
add_option('createTBL_version', '1.0');
}
答案 0 :(得分:4)
外键的工作原理如下:
FOREIGN KEY(table_field_name) REFERENCES [table_to_be_referred](referred_field)
该字段必须存在于引用表中,并且必须与引用者的定义完全匹配。由于它们的独特性,通常只引用主键。
以下是一个例子:
CREATE TABLE A (
id INT NOT NULL PRIMARY KEY,
name VARCHAR(10)
);
CREATE TABLE B (
idB INT NOT NULL PRIMARY KEY,
idA INT NOT NULL,
name VARCHAR(10),
FOREIGN KEY (idA) REFERENCES A(id)
);