2

我正在尝试在 MySQL 中使用 IF EXISTS,但我不断收到语法错误,我已经研究了正确的语法,但一切都不起作用......

我需要的是:如果查询存在,则更新否则插入新...

$queryString =  "IF EXISTS (SELECT * FROM $ONCALL_TABLE WHERE uid='$contextUser' AND submitid='$submitid' AND submitstatus=3) THEN UPDATE $ONCALL_TABLE SET uid='$contextUser', start_time='$onStr', end_time='$offStr', amount='$amount' ELSE INSERT INTO $ONCALL_TABLE (uid, start_time, end_time, amount) VALUES ('$contextUser','$onStr', '$offStr', '$amount') END IF";

错误消息:无法执行查询:您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 1 行的 'IF EXISTS (SELECT * FROM timesheet_oncall WHERE uid='admin' AND submitid='136545' 附近使用正确的语法

4

1 回答 1

2

REPLACE INTO是你需要的。http://dev.mysql.com/doc/refman/5.0/en/replace.html

REPLACE 的工作方式与 INSERT 完全相同,只是如果表中的旧行与 PRIMARY KEY 或 UNIQUE 索引的新行具有相同的值,则在插入新行之前删除旧行。

在你的情况下

REPLACE INTO 
$ONCALL_TABLE (uid, start_time, end_time, amount) 
VALUES ('$contextUser','$onStr', '$offStr', '$amount')
WHERE uid='$contextUser';

假设uid是一个PRIMARY KEYUNIQUE KEY

注意:由于您问题中的代码包含 SQL 注入缺陷,我建议您阅读本文。http://php.net/manual/en/security.database.sql-injection.php

于 2013-04-08T21:01:56.297 回答