1

、、の3つのテーブルがlt_hdefaultsありlt_hperiodsますlt_hrules。にはlt_hdefaults、特定の年のプロパティの行が1つあります。表ではlt_hperiods、複数の期間が存在する可能性があり、それらを季節と呼びます。表ではlt_hrules、期間ごとに複数のルールが存在する可能性があります。さて、私がうまくいかなかったこと:ユーザーがからレコードを削除するとき、lt_hdefaults削除されたレコードに関連する他のデータlt_hperiodslt_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);
4

3 に答える 3

6

ENGINE=MyISAM<-MyISAMはいかなる種類の外部キーもサポートしていません。代わりにInnoDBを使用してください。

于 2010-12-22T04:55:53.390 に答える
1

外部キー参照用innoDB

于 2010-12-22T04:57:43.320 に答える
0

このようなものが機能します..例として:

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;
于 2010-12-28T04:18:57.177 に答える