我已经尝试了大约2个小时,但无法正常工作,因此需要您的帮助。
我正在制作一个使用存储过程在MySQL数据库中进行更改的JavaFX应用程序。好吧,我需要一个存储过程,该过程接收6个参数,并根据寄存器是否存在进行更新或插入。
我收到语法错误,它不在乎我尝试什么。这是我的存储过程,现在它说UPDATE附近有错误:
DELIMITER $$
CREATE PROCEDURE `contactos`.`sp_guardar1` (IN foto varchar(100), IN nombres varchar(45), IN correo varchar(45), IN telf varchar(45), IN estado INT)
BEGIN
DECLARE IdAmi INT;
SET IdAmi = IdAmigo;
IF EXISTS (SELECT * FROM amigo WHERE IdAmigo = IdAmi)
UPDATE amigo SET foto = foto, nombres = nombres, correo = correo, telf = telf, estado = estado WHERE IdAmigo = @IdAmi
ELSE
INSERT INTO amigo(foto, nombres, correo, telf, estado) VALUES( foto, nombres, correo, telf, estado )
END
请帮忙 :)
最佳答案
您的IF
语句缺少关键字THEN
。它应该是
IF EXISTS (SELECT * FROM amigo WHERE IdAmigo = IdAmi)
THEN --<-- correction here
UPDATE amigo
SET foto = foto, nombres = nombres, correo = correo,
telf = telf, estado = estado
WHERE IdAmigo = @IdAmi
ELSE
INSERT INTO amigo(foto, nombres, correo, telf, estado)
VALUES( foto, nombres, correo, telf, estado )
END