首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将MySQL迁移到SQL Server --外键给出一个不清楚的错误(对我来说)

将MySQL迁移到SQL Server --外键给出一个不清楚的错误(对我来说)
EN

Stack Overflow用户
提问于 2012-06-23 01:03:14
回答 2查看 2.2K关注 0票数 2

我正在将一个数据库从MySQL 5迁移到SQL Server2008。我正在使用SQL Server迁移助手,但它给出了一个我不理解的错误。

我的表格如下所示:

代码语言:javascript
运行
复制
Table A
  ID (primary key)
  ProductionBatch
  Manufacturer
  LotNo
  Cost
  (and a bunch of other fields)

Table B
  ProductionBatch (primary key)
  Manufacturer (primary key)
  LotNo (primary key)
  Cost (primary key)
  (and a bunch of other fields)

在MySQL中,我在两个表中指出的四个字段构成了表B中的主键和表A中的外键;除非表A中的这些字段有匹配项,否则我不希望在表B中插入任何新记录。在MySQL中工作正常,但是迁移助手会给我以下错误:

代码语言:javascript
运行
复制
M2SS0048: Foreign Key does not contains all the columns of Primary/Unique Key

抛开语法错误不谈,我不知道这个错误是什么意思。是不是我允许表A中的那些字段为空值?或者它们在表A中不一定是唯一的?我尝试使用一个自动递增的整数作为表B的主键(而不是复合键),但似乎没有帮助。

任何想法或建议都将不胜感激。

编辑:为了清楚起见,我的外键在表B上。我首先将记录放入表A,然后将记录放入表B。但我不想将与表A中的任何记录都不匹配的记录放入表B。

第二次编辑:我被要求展示这个问题的代码。正如我告诉提问者的那样,我一直在用一个简单的例子来问这个问题;我的表格实际上更复杂,我认为一个简化的版本会更容易回答。但这是实际的表格,如果有人想看看我真正在做什么。我链接的实际字段是QCBatchID、LaboratoryName、构成和分数(我在上面的示例中使用了泛型字段)。

表A为:

代码语言:javascript
运行
复制
CREATE TABLE `chemistry_qc` (
`QCBatchID` varchar(12) COLLATE utf8_unicode_ci NOT NULL,
`LaboratoryName` varchar(45) COLLATE utf8_unicode_ci NOT NULL,
`Constituent` varchar(45) COLLATE utf8_unicode_ci NOT NULL,
`Fraction` enum('Not Reported','NA','Total','Dissolved','TR') COLLATE utf8_unicode_ci    
NOT NULL,
`LabSampleType` varchar(12) COLLATE utf8_unicode_ci DEFAULT NULL,
`PercentRecovery` decimal(5,2) DEFAULT NULL,
`RPD` double(5,2) DEFAULT NULL,
PRIMARY KEY (`QCBatchID`,`LaboratoryName`,`Constituent`,`Fraction`),
CONSTRAINT `fk_chem_qc_chem` FOREIGN KEY (`QCBatchID`, `LaboratoryName`,   `Constituent`, `Fraction`) REFERENCES `chemistry` (`LaboratoryName`, `QCBatchID`, `Constituent`, `Fraction`) ON DELETE NO ACTION ON UPDATE NO ACTION
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci

表B为:

代码语言:javascript
运行
复制
CREATE TABLE `chemistry` (
`ChemistryID` int(11) NOT NULL AUTO_INCREMENT,
`StationID` varchar(45) COLLATE utf8_unicode_ci NOT NULL,
`EventStartDateTime` datetime NOT NULL,
`SampleStartDateTime` datetime DEFAULT NULL,
`SampleEndDateTime` datetime DEFAULT NULL,
`SampleType` varchar(45) COLLATE utf8_unicode_ci DEFAULT NULL,
`FieldSampleID` varchar(45) COLLATE utf8_unicode_ci DEFAULT NULL,
`Matrix` varchar(12) COLLATE utf8_unicode_ci DEFAULT NULL,
`FieldQC` varchar(20) COLLATE utf8_unicode_ci DEFAULT NULL,
`GrabComposite` enum('C','G') COLLATE utf8_unicode_ci DEFAULT NULL,
`EventRepresentation` varchar(20) COLLATE utf8_unicode_ci DEFAULT NULL,
`CollectionMethod` varchar(12) COLLATE utf8_unicode_ci DEFAULT NULL,
`LaboratoryName` varchar(45) COLLATE utf8_unicode_ci DEFAULT NULL,
`LabSampleID` varchar(45) COLLATE utf8_unicode_ci DEFAULT NULL,
`ConstituentType` varchar(20) COLLATE utf8_unicode_ci DEFAULT NULL,
`Constituent` varchar(45) COLLATE utf8_unicode_ci DEFAULT NULL,
`CASNumber` varchar(20) COLLATE utf8_unicode_ci DEFAULT NULL,
`Fraction` enum('TR','Dissolved','Total','Not Reported','NA') COLLATE utf8_unicode_ci   DEFAULT NULL,
`QCBatchID` varchar(12) COLLATE utf8_unicode_ci DEFAULT NULL,
`SamplePrepMethod` varchar(45) COLLATE utf8_unicode_ci DEFAULT NULL,
`AnalysisType` varchar(5) COLLATE utf8_unicode_ci DEFAULT NULL,
`LabSampleType` varchar(4) COLLATE utf8_unicode_ci DEFAULT NULL,
`AnalyteType` varchar(5) COLLATE utf8_unicode_ci DEFAULT NULL,
`SamplePrepDate` date DEFAULT NULL,
`ReportedValue` double DEFAULT NULL,
`Units` varchar(12) COLLATE utf8_unicode_ci DEFAULT NULL,
`NumericQualifier` enum('>=','<=','>','<','=') COLLATE utf8_unicode_ci DEFAULT NULL,
`DataQualifier` text COLLATE utf8_unicode_ci,
`ReportingLimit` double DEFAULT NULL,
`MethodDetectionLimit` double DEFAULT NULL,
`PercentMoisture` decimal(3,2) DEFAULT NULL,
`MethodReference` varchar(12) COLLATE utf8_unicode_ci DEFAULT NULL,
`MethodNumber` varchar(20) COLLATE utf8_unicode_ci DEFAULT NULL,
`AnalysisDateTime` datetime DEFAULT NULL,
`Dilution` int(3) DEFAULT NULL,
`SampleNotes` longtext COLLATE utf8_unicode_ci,
PRIMARY KEY (`ChemistryID`),
KEY `fk_chemistry_event1` (`StationID`,`EventStartDateTime`),
KEY `fk_chemistry_laboratory1` (`LaboratoryName`),
KEY `ChemistryID` (`ChemistryID`,`StationID`,`EventStartDateTime`),
KEY `fk_chemistry_c_EventRepresentation1` (`EventRepresentation`),
KEY `fk_chemistry_c_collectionmethod1` (`CollectionMethod`),
KEY `fk_chemistry_c_sampletype1` (`SampleType`),
KEY `fk_chemistry_c_matrix` (`Matrix`),
KEY `fk_chemistry_c_methods`      (`Constituent`,`ConstituentType`,`Units`,`MethodReference`,`MethodNumber`),
KEY `fk_chemistry_sampleprepmethod1` (`SamplePrepMethod`),
KEY `fk_chemistry_analysistype` (`AnalysisType`),
KEY `fk_chemistry_analytetype` (`AnalyteType`),
KEY `fk_chemistry_labsampletype` (`LabSampleType`),
KEY `ChemistryID_2` (`ChemistryID`,`StationID`),
KEY `LaboratoryName` (`LaboratoryName`,`Constituent`,`Fraction`,`QCBatchID`),
KEY `QCBatchID_4` (`QCBatchID`,`LaboratoryName`,`Constituent`,`Fraction`),
KEY `LaboratoryName_4` (`LaboratoryName`,`QCBatchID`,`Constituent`,`Fraction`),
CONSTRAINT `chemistry_analysistype` FOREIGN KEY (`AnalysisType`) REFERENCES   `c_analysistype` (`AnalysisType`) ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT `chemistry_ibfk_10` FOREIGN KEY (`SamplePrepMethod`) REFERENCES `c_sampleprepmethod` (`SamplePrepMethod`) ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT `chemistry_ibfk_11` FOREIGN KEY (`Constituent`, `ConstituentType`, `Units`, `MethodReference`, `MethodNumber`) REFERENCES `c_methods` (`Constituent`, `ConstituentType`, `Units`, `MethodReference`, `MethodNumber`) ON DELETE NO ACTION ON   UPDATE NO ACTION,
CONSTRAINT `chemistry_ibfk_2` FOREIGN KEY (`AnalyteType`) REFERENCES `c_analytetype` (`AnalyteType`) ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT `chemistry_ibfk_3` FOREIGN KEY (`CollectionMethod`) REFERENCES `c_collectionmethod` (`CollectionMethod`) ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT `chemistry_ibfk_4` FOREIGN KEY (`EventRepresentation`) REFERENCES `c_eventrepresentation` (`EventRepresentation`) ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT `chemistry_ibfk_5` FOREIGN KEY (`Matrix`) REFERENCES `c_matrix` (`Matrix`) ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT `chemistry_ibfk_6` FOREIGN KEY (`SampleType`) REFERENCES `c_sampletype` (`SampleType`) ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT `chemistry_ibfk_7` FOREIGN KEY (`StationID`, `EventStartDateTime`)   REFERENCES `event` (`StationID`, `EventStartDateTime`) ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT `chemistry_ibfk_8` FOREIGN KEY (`LaboratoryName`) REFERENCES `laboratory` (`LaboratoryName`) ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT `chemistry_ibfk_9` FOREIGN KEY (`LabSampleType`) REFERENCES `c_labsampletype` (`LabSampleType`) ON DELETE NO ACTION ON UPDATE NO ACTION) ENGINE=InnoDB AUTO_INCREMENT=206971 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci  
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-06-23 06:49:05

我将只保留两个表中的相关列:

表A:

代码语言:javascript
运行
复制
CREATE TABLE chemistry_qc (
  QCBatchID       varchar(12) COLLATE utf8_unicode_ci  NOT NULL,
  LaboratoryName  varchar(45) COLLATE utf8_unicode_ci  NOT NULL,
  Constituent     varchar(45) COLLATE utf8_unicode_ci  NOT NULL,
  Fraction        enum('Not Reported','NA','Total','Dissolved','TR') 
                              COLLATE utf8_unicode_ci  NOT NULL,
  --- more columns

  PRIMARY KEY (QCBatchID, LaboratoryName, Constituent, Fraction),

  CONSTRAINT fk_chem_qc_chem 
    FOREIGN KEY (QCBatchID, LaboratoryName, Constituent, Fraction) 
      REFERENCES chemistry 
                (LaboratoryName, QCBatchID, Constituent, Fraction) 
    ON DELETE NO ACTION 
    ON UPDATE NO ACTION

) ENGINE=InnoDB 
  DEFAULT CHARSET=utf8 
  COLLATE=utf8_unicode_ci ;

表B:

代码语言:javascript
运行
复制
CREATE TABLE chemistry (
  ChemistryID     int(11) NOT NULL AUTO_INCREMENT,
  --- more columns
  LaboratoryName  varchar(45) COLLATE utf8_unicode_ci  DEFAULT NULL,
  --- more columns
  Constituent     varchar(45) COLLATE utf8_unicode_ci  DEFAULT NULL,
  Fraction        enum('TR','Dissolved','Total','Not Reported','NA') 
                             COLLATE utf8_unicode_ci  DEFAULT NULL,
  QCBatchID       varchar(12) COLLATE utf8_unicode_ci  DEFAULT NULL,
  --- more columns

PRIMARY KEY (ChemistryID),

KEY fk_chemistry_laboratory1 (LaboratoryName),
--- more KEYs
KEY LaboratoryName (LaboratoryName, Constituent, Fraction, QCBatchID),
KEY QCBatchID_4 (QCBatchID, LaboratoryName, Constituent, Fraction),
      --- this key should have been needed for your FK reference

KEY LaboratoryName_4 (LaboratoryName , QCBatchID, Constituent, Fraction),
      --- this key was needed for your FK reference

--- CONSTRAINTS 

) ENGINE=InnoDB 
  AUTO_INCREMENT=206971 
  DEFAULT CHARSET=utf8 
  COLLATE=utf8_unicode_ci ; 

对于记录,这是从表A (chemistry_qc)到表B (chemistry)FOREIGN KEY

FOREIGN KEY约束中有两个错误。第一个是由您完成的(并得到MySQL的协助)。你有两个引用和引用的组合键,它们的顺序不同:

代码语言:javascript
运行
复制
CONSTRAINT fk_chem_qc_chem 
    FOREIGN KEY (QCBatchID, LaboratoryName, Constituent, Fraction) 
      REFERENCES chemistry 
                (LaboratoryName, QCBatchID, Constituent, Fraction) 
             ---    |||             |||   
             --- *** wrong order here *** ---

它应该是:

代码语言:javascript
运行
复制
CONSTRAINT fk_chem_qc_chem 
    FOREIGN KEY (QCBatchID, LaboratoryName, Constituent, Fraction) 
      REFERENCES chemistry 
                (QCBatchID, LaboratoryName, Constituent, Fraction) 

当你试图在VARCHAR(45)引用VARCHAR(12)的地方添加一个FK时,MySQL应该会抱怨,但它没有。

第二个错误是您的FK引用的键既不是PRIMARY也不是UNIQUE。MySQL的另一个帮助,通过允许FK到非唯一的列化合物来解决问题。

因此,您应该(case-1)在表chemistry中将该键声明为UNIQUE,或者(case-2)您的FK应该是相反的,从表BA (它在这个复合上已经有一个PRIMARY KEY )。

哪一个是正确的,取决于你的数据的关系:

是否每个chemistry都有0或1个chemistry_qc?这是情况1(并且您具有1:1关系,或者更准确地说是0..1 :: 1)。

是否每个chemistry_qc都有0或更多的chemistry?这是第二种情况(并且您有一个常见的1:n关系,在上面的表示法中是一个1 :: 0..n )。

最后,应该清楚的是,导致迁移错误的原因是您使用的向导(正确地)期望FOREIGN KEY约束引用PRIMARYUNIQUE复合。

票数 1
EN

Stack Overflow用户

发布于 2012-06-23 01:20:16

错误本身只是说明您的FK没有包含构成表B的PK的所有四列。请仔细检查您的FK规范,看看它是否包含所有四列。

话虽如此,@Kevin的评论(在问题中)是正确的,FK不是这样工作的,你必须首先在PK表中插入。

编辑:现在我看到FK在表B而不是A上(根据你的评论和编辑)这就是问题所在,你在表B中有一个引用A的FK,但是A上的PK只是一个ID……这不会起作用,表B上的FK和它引用的表上的PK (在本例中是A)需要相同。您可以从A中删除ID列作为PK,并使其键与B的组合键相同,如果您希望这样做的话。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11160866

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档