bin
发布于

触发器问题

有两个表,表(文件)和表(哈希),我想创建一个过程来插入新的(文件),如果不存在,它将添加一个(哈希),然后将其(ID)插入到(文件)表中,如果存在,请选择(ID)并插入它,我还必须使用(在文件插入触发器之前)我尝试过,但它要么给我一个 CONSTRAINT 错误,要么插入哈希并且没有插入文件。

  CREATE TABLE `Hashes` (
  `ID` int(255) unsigned NOT NULL AUTO_INCREMENT,
  `Hash` varchar(255) NOT NULL,
  `Counter` int(255) NOT NULL DEFAULT '1',
  PRIMARY KEY (`ID`),
  UNIQUE KEY `Hash` (`Hash`)
)

  CREATE TABLE `Files` (
  `ID` int(255) unsigned NOT NULL AUTO_INCREMENT,
  `Name` varchar(255) NOT NULL,
  `ParentPath` varchar(255) DEFAULT NULL,
  `Size` double NOT NULL,
  `Date` date NOT NULL,
  `ParentID` int(255) unsigned NOT NULL DEFAULT '0',
  `HashID` int(255) unsigned DEFAULT NULL,
  PRIMARY KEY (`ID`),
  KEY `fk_Hash_ID` (`HashID`),
  CONSTRAINT `fk_Hash_ID` FOREIGN KEY (`HashID`) REFERENCES `hashes` (`ID`)
)

////////
CREATE PROCEDURE SP_Files_Insert
(                      
parmName VARCHAR(255),                 
parmParentPath VARCHAR(255),         
parmSize DOUBLE,   
parmDate DATE,
parmParentID INTEGER,
parmHash VARCHAR(255)
)
BEGIN
    
    INSERT INTO Files( Name, ParentPath, Size, Date, ParentID, HashID) 
    VALUES(parmName, parmParentPath, parmSize, parmDate, parmParentID,    LAST_INSERT_ID());

END;

////////////
CREATE TRIGGER TR_Insert_File BEFORE INSERT ON Files 
FOR EACH ROW
BEGIN
  
  INSERT INTO Hash( Hash, Counter) 
    VALUE( parmHash, 1) 
    ON DUPLICATE KEY UPDATE ID = LAST_INSERT_ID(ID), Counter = Counter + 1;
 
END;

报错信息:无法添加或更新子行:外键约束失败 (cloudimagesdb.文件、约束fk_Hash_ID外键 (HashID) 在更新级联上引用哈希

浏览 (69)
点赞
收藏
1条评论
Klustron小助手
Klustron小助手
试试在触发器中使用 delimiter,如下所示, delimiter \\ CREATE TRIGGER TR_Insert_File BEFORE INSERT ON Files FOR EACH ROW BEGIN INSERT INTO Hash( Hash, Counter) VALUE( parmHash, 1) ON DUPLICATE KEY UPDATE ID = LAST_INSERT_ID(ID), Counter = Counter + 1; END\\ delimiter ;
点赞
评论