我已经对此进行了多次审查,但找不到它不应该起作用的原因,希望有人可以揭示我所缺少的内容,这是我准备好的声明。
在初始化准备好的语句后直接执行var_dump
on时$query
,它返回 false。
$query = $link->prepare("IF (EXISTS(SELECT * FROM banned WHERE ipAddr=? OR uid=?)) THEN UPDATE banned SET isBanned='1', ipAddr=?, uid=?, bannedAt=NOW(), reason=? WHERE ipAddr=? OR uid=? ELSE INSERT INTO banned (isBanned, ipAddr, uid, bannedAt, reason) VALUES('1', ?, ?, NOW(), ?) END IF");
$query->bind_param("sisissisis", $details['IP'], $details['uid'], $details['IP'], $details['uid'], $details['reason'], $details['IP'], $details['uid'], $details['IP'], $details['uid'], $details['reason']);
表结构
banned
------
id, uid, ipAddr, bannedAt, reason, isBanned
注意:如果这不是达到相同结果的最佳方法,请提供建议