Error en trigger - Error Code: 1452. Cannot add or update a child row: a foreign key constraint fail
Publicado por Guillermo (1 intervención) el 16/05/2020 19:11:25
amigos tengo problemas con el trigger InsertarPrimeraLlaver al insertar datos a acceso me tira el siguiente error:
Error Code: 1452. Cannot add or update a child row: a foreign key constraint fails (`login`.`historicollave`, CONSTRAINT `fk_idAcceso` FOREIGN KEY (`idAcceso`) REFERENCES `acceso` (`idAcceso`))
Error Code: 1452. Cannot add or update a child row: a foreign key constraint fails (`login`.`historicollave`, CONSTRAINT `fk_idAcceso` FOREIGN KEY (`idAcceso`) REFERENCES `acceso` (`idAcceso`))
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
create database LOGIN;
Use LOGIN;
/*Crear Tabla Usuario */
create table Usuario(
idUsuario int not null auto_increment,
Nombre varchar(45) not null,
Appat varchar(45) not null,
Apmat varchar(45) not null,
primary key(idUsuario)
);
/*Crear Tabla Acceso*/
create table Acceso(
idAcceso int not null auto_increment,
Usuario varchar(45) not null,
llave varchar(45) not null,
idUsuario int not null,
primary key(idAcceso),
FOREIGN KEY (idUsuario) REFERENCES Usuario(idUsuario)
);
/*Crear Tabla HistoricoLlave*/
create table HistoricoLlave(
idHistoricoLlave int not null auto_increment,
LlaveAnterior varchar(45) not null,
Fecha Datetime not null,
idAcceso int not null,
primary key(idHistoricoLlave),
CONSTRAINT fk_idAcceso FOREIGN KEY (idAcceso) REFERENCES Acceso(idAcceso)
);
/*Crear Tabla HistoricoAcceso*/
create table HistoricoAcceso(
idHistoricoAcceso int not null auto_increment,
Fecha Datetime not null,
idAcceso int not null,
primary key(idHistoricoAcceso),
FOREIGN KEY (idAcceso) REFERENCES Acceso(idAcceso)
);
/*Triger Insertar Primera llave de Historico de Llave*/
CREATE TRIGGER InsertarPrimeraLlaver
BEFORE INSERT ON Acceso
FOR EACH ROW
insert into HistoricoLlave SET LlaveAnterior = NEW.llave and idAcceso = new.idAcceso;
/*Triger Actualizar LlaveAnterior de Historico de Llave*/
DELIMITER $$
CREATE TRIGGER actualizarHistoricoLlave
BEFORE UPDATE ON Acceso
FOR EACH ROW
BEGIN
IF NEW.llave <> OLD.llave
THEN
insert into HistoricoLlave(LlaveAnterior,Fecha,idAcceso) values(NEW.llave,now(),new.idAcceso);
END IF ;
END$$
DELIMITER ;
/*Insertar Datos de Usuario*/
insert into Usuario(Nombre,Appat,Apmat) values("admin","admin","admin");
/*Insertar Datos de Acceso*/
insert into Acceso(Usuario,llave,idUsuario) values("admin","admin","1");
Valora esta pregunta


0