- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
您能否说明为什么 CHARGEITEM、INVOICE 和 PAYMENT 可能会失败?我在这里缺少什么?
我检查了这些:
这是完整的脚本(表 6、8 和 9 失败):
CREATE TABLE `BUILDING` (
`ID` BIGINT NOT NULL AUTO_INCREMENT,
`NAME` varchar(255) DEFAULT NULL,
`ADDRESS` varchar(255) DEFAULT NULL,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `ROOM` (
`ID` BIGINT NOT NULL AUTO_INCREMENT,
`BUILDINGID` BIGINT NULL DEFAULT NULL,
`FLOORNUM` varchar(255) DEFAULT NULL,
`DOORNUM` varchar(255) DEFAULT NULL,
`TYPE` varchar(255) DEFAULT NULL,
PRIMARY KEY (`ID`),
KEY `BUILDINGID` (`BUILDINGID`),
FOREIGN KEY (`BUILDINGID`) REFERENCES `BUILDING` (`ID`) ON DELETE RESTRICT
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `BOOKING` (
`ID` BIGINT NOT NULL AUTO_INCREMENT,
`ENTRYDATE` datetime DEFAULT NULL,
`GUESTNAME` varchar(255) DEFAULT NULL,
`GUESTCONTACT` varchar(255) DEFAULT NULL,
`GUESTADDRESS` varchar(255) DEFAULT NULL,
`GUESTIDTYPE` varchar(255) DEFAULT NULL,
`GUESTIDNUM` varchar(255) DEFAULT NULL,
`GUESTPASSPORTNUM` varchar(255) DEFAULT NULL,
`NOTES` varchar(255) DEFAULT NULL,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `BOOKINGROOM` (
`ID` BIGINT NOT NULL AUTO_INCREMENT,
`BOOKINGID` BIGINT NULL DEFAULT NULL,
`ROOMID` BIGINT NULL DEFAULT NULL,
`STARTDATE` date DEFAULT NULL,
`ENDDATE` date DEFAULT NULL,
PRIMARY KEY (`ID`),
KEY `BOOKINGID` (`BOOKINGID`),
KEY `ROOMID` (`ROOMID`),
FOREIGN KEY (`BOOKINGID`) REFERENCES `BOOKING` (`ID`) ON DELETE RESTRICT,
FOREIGN KEY (`ROOMID`) REFERENCES `ROOM` (`ID`) ON DELETE RESTRICT
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `CHARGE` (
`ID` BIGINT NOT NULL AUTO_INCREMENT,
`CHARGEGROUP` varchar(255) DEFAULT NULL,
`CHARGECODE` varchar(255) DEFAULT NULL,
`NOTES` varchar(255) DEFAULT NULL,
`UNIT` varchar(255) DEFAULT NULL,
`UNITRATE` double NOT NULL,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `CHARGEITEM` (
`ID` BIGINT NOT NULL AUTO_INCREMENT,
`BOOKINGID` BIGINT NULL DEFAULT NULL,
`ROOMID` BIGINT NULL DEFAULT NULL,
`CHARGEID` BIGINT NULL DEFAULT NULL,
`ENTRYSTAFFID` BIGINT NULL DEFAULT NULL,
`ENTRYDATE` datetime DEFAULT NULL,
`VALUEDATE` date DEFAULT NULL,
`UNIT` varchar(255) DEFAULT NULL,
`UNITRATE` double NOT NULL,
`UNITS` double NOT NULL,
`AMOUNT` double NOT NULL,
`NOTES` varchar(255) DEFAULT NULL,
`INVOICEID` BIGINT NULL DEFAULT NULL,
PRIMARY KEY (`ID`),
KEY `INVOICEID` (`INVOICEID`),
KEY `ROOMID` (`ROOMID`),
KEY `BOOKINGID` (`BOOKINGID`),
KEY `CHARGEID` (`CHARGEID`),
FOREIGN KEY (`INVOICEID`) REFERENCES `INVOICE` (`ID`) ON DELETE RESTRICT,
FOREIGN KEY (`ROOMID`) REFERENCES `ROOM` (`ID`) ON DELETE RESTRICT,
FOREIGN KEY (`BOOKINGID`) REFERENCES `BOOKING` (`ID`) ON DELETE RESTRICT,
FOREIGN KEY (`CHARGEID`) REFERENCES `CHARGE` (`ID`) ON DELETE RESTRICT
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `DROPDOWNENTRY` (
`ID` BIGINT NOT NULL AUTO_INCREMENT,
`MODULE` varchar(255) DEFAULT NULL,
`POSITION` int(11) NOT NULL,
`KEY` varchar(255) DEFAULT NULL,
`VALUE` varchar(255) DEFAULT NULL,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `INVOICE` (
`ID` BIGINT NOT NULL AUTO_INCREMENT,
`BOOKINGID` varchar(255) NOT NULL,
`ENTRYSTAFFID` BIGINT NULL DEFAULT NULL,
`ENTRYDATE` datetime DEFAULT NULL,
`AUTHSTAFFID` BIGINT NULL DEFAULT NULL,
`AUTHDATE` datetime DEFAULT NULL,
`NETAMOUNT` double NOT NULL,
`TAX1` double NOT NULL,
`TAX2` double NOT NULL,
`TAX3` double NOT NULL,
`TOTALTAX` double NOT NULL,
`TOTALINCLTAX` double NOT NULL,
PRIMARY KEY (`ID`),
KEY `BOOKINGID` (`BOOKINGID`),
FOREIGN KEY (`BOOKINGID`) REFERENCES `BOOKING` (`ID`) ON DELETE RESTRICT
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `PAYMENT` (
`ID` BIGINT NOT NULL AUTO_INCREMENT,
`INVOICEID` BIGINT NULL DEFAULT NULL,
`AMOUNTPAID` double NOT NULL,
`PAYMODE` varchar(255) DEFAULT NULL,
`ENTRYDATE` datetime DEFAULT NULL,
`VALUEDATE` date DEFAULT NULL,
`REALISATIONDATE` date DEFAULT NULL,
`BANKCODE` varchar(255) DEFAULT NULL,
`INSTRUMENTNUM` varchar(255) DEFAULT NULL,
`POSCODE` varchar(255) DEFAULT NULL,
`REALISATIONSTATUS` varchar(255) DEFAULT NULL,
`NOTES` varchar(255) DEFAULT NULL,
PRIMARY KEY (`ID`),
KEY `INVOICEID` (`INVOICEID`),
FOREIGN KEY (`INVOICEID`) REFERENCES `INVOICE` (`ID`) ON DELETE RESTRICT
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `RESERVATION` (
`ID` BIGINT NOT NULL AUTO_INCREMENT,
`ENTRYDATE` datetime DEFAULT NULL,
`FROMDATE` date DEFAULT NULL,
`TODATE` date DEFAULT NULL,
`NUMROOMS` int(11) NOT NULL,
`GUESTNAME` varchar(255) DEFAULT NULL,
`GUESTCONTACT` varchar(255) DEFAULT NULL,
`GUESTADDRESS` varchar(255) DEFAULT NULL,
`NOTES` varchar(255) DEFAULT NULL,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
最佳答案
两个问题:
INVOICES
当您在另一个表中引用它时不存在。在引用之前定义表或在创建所有表后定义约束。在 INVOICES
表中,您正在定义数据类型 varchar(255),但在外键中,它指的是 bigint 列 - 不起作用。
在 INVOICES
表中,
`BOOKINGID` varchar(255) NOT NULL,
将其更改为:
`BOOKINGID` BIGINT NOT NULL,
这里都修复了 -
关于MySQL 1215 : Cannot add foreign key constraint,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42595683/
仍在习惯正则表达式中的环视,但似乎无法理解 \b(?>! key)foreign\b 要成为正确的解决方案?我试图在某些文本中找到所有外来词的实例,但不是外键或外键。 最佳答案 前瞻需要在 forei
我有一个外国表,例如: CREATE FOREIGN TABLE film ( id varchar(40) NOT NULL, title varcha
我的意思是例如我可以创建表 create table XTable ( idt int not null primary key, value nvarchar(50), idq int,
我有以下表格: 财务: PK_FinancialID FK_SchoolID 学校: PK_SchoolID 类: PK_ClassID FK_SchoolID 类(class)名 Class 和 F
我有一个旧数据库,我不能用每个实体中具有外键属性的两个实体更改它: EntityOne ForeignKey1 (pointing to EntityTwo.ForeignKey2) Enti
当我尝试运行代码时,出现此错误 Cannot add or update a child row: a foreign key constraint fails (hotel_info.results
好的,我尝试了这种从外国翻译过来的方法,它确实有效我在我的库中的 structs.lisp 文件中定义了这些,它在我所有其他依赖项之前首先加载 (cffi:defcstruct (cv-size :c
我有一个 Django 程序员的问题应该很简单,但目前我不知道如何解决。 我有这三个模型(我尽量简化): class Nations(models.Model): label = models
真的很讨厌占用别人的时间,但问题似乎并没有消失。 我考虑了 http://verysimple.com/2006/10/22/mysql-error-number-1005-cant-create-t
我需要一双新的眼睛来看看我到底做错了什么。 CREATE TABLE IF NOT EXISTS `spring_normalize`.`users` ( `username` VARCHAR(6
我正在尝试在表中添加外键约束。我的表结构是:表请购单 我想在下一张表中添加申请表的外键 申请批准 当我尝试使用以下 SQL 查询添加外键约束时: ALTER TABLE `requisition_ap
每当我尝试将数据插入“学生”表时,都会收到此错误。下面是两个表,我使用的是MySql: 学生表: | Field | Type | Null | Key | Defaul
我收到错误代码 1215:无法为子表添加外键约束。父表具有复合主键。我想使用该复合主键作为子表中的外键。请指导我。 父表 CREATE TABLE health.procedures( Spe
var state = require('./state') module.exports = function (sequelize, DataTypes) { var city = seq
我可以通过 this case 部分解决这个问题 不幸的是,Preload() 函数似乎无法在相关对象集中进行更深入的研究。 澄清一下,我有以下模型: type Room struct {
我正在使用 Laravel 6。我创建了一些迁移,但我无法让它们成功运行。这些是我的迁移。 public function up() { Schema::create('nationa
这是我的总输出: Executing SQL script in server ERROR: Error 1215: Cannot add foreign key constraint CREATE
我有 postgres 数据库,我的应用程序是使用 django 构建的,我使用 south migration 来维护数据库模式。我有以下场景: user_table与userclickstream
简单的问题。只是想知道是否可以在不需要我在 Java 代码中手动强制执行此约束的情况下完成此操作。这两个外键(一起在同一个表中)都引用另一个表,但对于每一行,它们不得指向同一个外项。 link tex
我正在为我的模型关联使用 Sails 和 Waterline,但我不确定要做什么才能修复我在尝试更新 PageChild 对象时收到的错误。 module.exports = { tableN
我是一名优秀的程序员,十分优秀!