Bases de Datos - Error en trigger - Error Code: 1452. Cannot add or update a child row: a foreign key constraint fail

 
Vista:

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`))


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
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder