My 'ON DELETE CASCADE ' does not work

懵懂的女人 提交于 2019-12-02 03:08:27

ENGINE=MyISAM <-- MyISAM doesn't support any kind of foreign keys. Use InnoDB instead.

for Foreign key referencing use innoDB

user403295

Something like this works..as an example:

SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";

CREATE TABLE IF NOT EXISTS lt_hperiods ( 
    period_id          int(255)      NOT NULL,  
    lt_id              int(255)      NOT NULL,
    lt_year            year(4)       NOT NULL DEFAULT '0000',  
    period_name        varchar(45)   NOT NULL,  
    min_stay           int(10)       NOT NULL,
    max_stay           int(10)       NOT NULL,   
    fromDate           date          NOT NULL,
    toDate             date          NOT NULL,  
    weekly_rate        float(10,2)   DEFAULT NULL, 
    nightly_rate       float(10,2)   NOT NULL,  
    arriveDepartDays   varchar(150)  DEFAULT 'sunday,monday,tuesday,wednesday,thursday,friday,saturday',
    noArriveDepartDays varchar(150)  DEFAULT NULL,

    PRIMARY KEY (period_id),
    INDEX (lt_id),
    INDEX (lt_year),
    CONSTRAINT FOREIGN KEY (`lt_id`, `lt_year`) 
    REFERENCES lt_hdefaults(`lt_id`, `lt_year`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=107;



SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";

CREATE TABLE IF NOT EXISTS lt_hrules (
    period_id      int(255)     NOT NULL,
    lt_id          int(255)     NOT NULL,
    lt_year        year(4)      NOT NULL DEFAULT '0000',
    rule_name      varchar(45)  NOT NULL,
    night_of_stay  int(10)      NOT NULL,
    fixed_rate     float(10,2)  NOT NULL,

    PRIMARY KEY (period_id,lt_id,night_of_stay),
    INDEX(period_id),
    CONSTRAINT FOREIGN KEY (`period_id`)
    REFERENCES lt_hperiods(`period_id`) ON DELETE CASCADE
) ENGINE=InnoDB  DEFAULT CHARSET=latin1;
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!