Mysql 我的';删除级联';不起作用

Mysql 我的';删除级联';不起作用,mysql,cascade,cascading-deletes,Mysql,Cascade,Cascading Deletes,我有三个表:lt\u hdefaults、lt\u hperiods和lt\u hrules。在lt\u hdefaults中,某一特定年份的某一物业有一行。在lt\u hperiods表中,可能有多个时段,称为季节。在lt_hrules表中,每个期间可能有多个规则。现在,我无法做到的是:当用户从lt\u hdefaults中删除一条记录时,应该从lt\u hperiods和lt\hrules表中删除与已删除记录相关的其他数据。我正试图通过使用 FOREIGN KEY (lt_year,lt_i

我有三个表:
lt\u hdefaults
lt\u hperiods
lt\u hrules
。在
lt\u hdefaults
中,某一特定年份的某一物业有一行。在
lt\u hperiods
表中,可能有多个时段,称为季节。在
lt_hrules
表中,每个期间可能有多个规则。现在,我无法做到的是:当用户从
lt\u hdefaults
中删除一条记录时,应该从
lt\u hperiods
lt\hrules
表中删除与已删除记录相关的其他数据。我正试图通过使用

FOREIGN KEY (lt_year,lt_id) REFERENCES lt_hdefaults(lt_year,lt_id) ON DELETE CASCADE
但是,它不起作用。我知道它看起来很长,但不是很复杂。如果有人有任何想法,我将不胜感激。我知道如何使用mysql,但我不是这方面的专家。非常感谢

样本如下:

CREATE TABLE IF NOT EXISTS lt_hdefaults (
  lt_year year(4) NOT NULL DEFAULT '0000',
  lt_id int(255) NOT NULL DEFAULT '0',
  period_name varchar(45) NOT NULL DEFAULT 'Default',
  min_stay int(10) NOT NULL DEFAULT '1',
  max_stay int(10) NOT NULL,
  weekly_rate float(10,2) NOT NULL,
  nightly_rate float(10,2) NOT NULL,
  PRIMARY KEY (lt_year,lt_id)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;    

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),
  FOREIGN KEY (lt_year,lt_id) REFERENCES lt_hdefaults(lt_year,lt_id) ON DELETE CASCADE
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=107 ;    

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),
  FOREIGN KEY (period_id) REFERENCES lt_hperiods(period_id) ON DELETE CASCADE
) ENGINE=MyISAM DEFAULT CHARSET=latin1;    

INSERT INTO lt_hdefaults (lt_year, lt_id, period_name, min_stay, max_stay, weekly_rate, nightly_rate, min_guests, max_guests, surchargeAboveGuests, chargePerGuestFee, bondFee, cleaningFee, bookingServiceFee) VALUES
(2010, 2, 'Default', 0, 0, 1200.00, 171.43, 2, 5, 6, 85.00, 1000.00, 120.00, 0.00),
(2010, 3, 'Default', 0, 0, 1300.00, 185.71, 2, 5, 6, 44.00, 1000.00, 120.00, 0.00);

INSERT INTO lt_hperiods (period_id, lt_id, lt_year, period_name, min_stay, max_stay, fromDate, toDate, weekly_rate, nightly_rate, arriveDepartDays, noArriveDepartDays) VALUES
(105, 3, 2010, 'winter', 2, 66, '2010-12-22', '2011-01-15', 1500.00, 214.29, 'Monday,Tuesday,Wednesday,Thursday', 'Friday,Saturday,Sunday'),
(106, 3, 2010, 'summer', 2, 77, '2011-01-14', '2011-01-28', 4000.00, 571.43, 'Monday,Tuesday,Wednesday,Thursday,Friday,Saturday', 'Sunday');

INSERT INTO lt_hrules (period_id, lt_id, lt_year, rule_name, night_of_stay, fixed_rate) VALUES
(106, 3, 2010, 'r2', 2, 222.00),
(106, 3, 2010, 'r1', 1, 111.00),
(105, 3, 2010, 'r2', 2, 222.00),
(105, 3, 2010, 'r1', 1, 111.00);

ENGINE=MyISAM
对于外键引用,请使用
innoDB
类似的方法。例如:

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;

非常感谢,这项工作需要额外的修改。。(对于其他面临同样问题的人,我也会补充另一个答案。)