首次创建 table 时,在 table 之间创建关系

Create a relationship between the tables when the table is first created

我用mysql 在我的数据库中 我想创建多个 table 具有删除和更新关系

举个例子 我想 link 个人资料 table 给用户 table 将用户 table 的 mm_id_user 列与配置文件 table

的 mm_id_profile 列相关联

我实际尝试做的是这个例子,但它对我不起作用

用于创建用户的代码 table 并且成功创建了 table

CREATE TABLE users (
    mm_email VARCHAR(255) NOT NULL,
    mm_id_user int NOT NULL AUTO_INCREMENT,
    mm_name VARCHAR(25) NOT NULL,
    mm_password VARCHAR(255) NOT NULL,
    mm_code_reset_pass VARCHAR(100) NOT NULL,
    mm_code_check_email VARCHAR(100) NOT NULL,
    mm_status CHAR(1) NOT NULL DEFAULT '0',
    mm_date_create_account TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
    mm_date_last_login TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
    mm_is_login CHAR(1) NOT NULL DEFAULT '0',

    PRIMARY KEY (mm_id_user, mm_email)
)ENGINE=InnoDB DEFAULT CHARSET=utf8 DEFAULT COLLATE utf8_unicode_ci;

用于创建配置文件的代码 table。他未能创建 table

CREATE TABLE profiles (
    mm_id_profile VARCHAR(255) NOT NULL,
    mm_image_user TEXT NOT NULL,
    mm_num_stores_all VARCHAR(4) NOT NULL,
    mm_num_stores_exist VARCHAR(4) NOT NULL,
    mm_name_public VARCHAR(25) NOT NULL,
    mm_email_public VARCHAR(255) NOT NULL,
    mm_phone_public VARCHAR(20) NOT NULL,
    mm_location_public TEXT NOT NULL,
    mm_update_date TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,

    INDEX index_profiles(mm_name_public, mm_email_public),
    PRIMARY KEY (mm_id_profile),
    FOREIGN KEY (mm_id_profile) REFERENCES users(mm_email) ON DELETE CASCADE
)ENGINE=InnoDB DEFAULT CHARSET=utf8 DEFAULT COLLATE utf8_unicode_ci;

但是如果您从配置文件中删除以下行 table,它将被创建 但是这两个tables

肯定是没有关系的
FOREIGN KEY (mm_id_profile) REFERENCES users(mm_email) ON DELETE CASCADE

这是创建配置文件时出现的错误消息table

#1005 - Can't create table `mustforu_test`.`profiles` (errno: 150 "Foreign key constraint is incorrectly formed") (Details…)

没有理由把mm_id_usermm_email都放在users的主键中。如果您希望电子邮件是唯一的,它应该有自己的唯一索引。您当前的主键将允许具有不同 ID 的重复电子邮件。

CREATE TABLE users (
    mm_email VARCHAR(255) NOT NULL,
    mm_id_user int NOT NULL AUTO_INCREMENT,
    mm_name VARCHAR(25) NOT NULL,
    mm_password VARCHAR(255) NOT NULL,
    mm_code_reset_pass VARCHAR(100) NOT NULL,
    mm_code_check_email VARCHAR(100) NOT NULL,
    mm_status CHAR(1) NOT NULL DEFAULT '0',
    mm_date_create_account TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
    mm_date_last_login TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
    mm_is_login CHAR(1) NOT NULL DEFAULT '0',

    PRIMARY KEY (mm_id_user),
    UNIQUE KEY (mm_email)
)ENGINE=InnoDB DEFAULT CHARSET=utf8 DEFAULT COLLATE utf8_unicode_ci;

mm_email 自己的索引将允许 profiles 中的外键起作用。