mysql - PHP SQL IF NOT EXISTS 将不起作用

标签 mysql

我有一个关于 SQL (php) 的问题,我想在我的表中插入数据。但我想使用 IF NOT EXIST 值。 我试过的:

INSERT INTO vrienden (id, userid, vriendmetid, accepted) VALUES (null, '1', '20', '0') WHERE NOT EXISTS (SELECT * FROM vrienden WHERE userid='1' AND vriendmetid='20')

我不确定出了什么问题,因为我收到以下错误:

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE NOT EXISTS (SELECT * FROM vrienden WHERE userid='1' AND vriendmetid='20')' at line 1

谢谢。

最佳答案

你想要 insert 。 . .选择,而不是插入。 . .值(value)观:

INSERT INTO vrienden (id, userid, vriendmetid, accepted) 
     SELECT x.*
     FROM (select null as id, '1' as userid, '20' as vriendmetid, '0' as accepted) x
     WHERE NOT EXISTS (SELECT 1 FROM vrienden v WHERE v.userid = x.userid AND v.vriendmetid = x.vriendmetid);

但是,您可能不应该在 INSERT 中执行此操作。相反,创建一个唯一的索引/约束:

create unique index unq_vrienden_userid_vriendmetid on vrienden(userid, vriendmetid);

这样,数据库将确保列的唯一性,因此您的应用程序不必这样做。

关于mysql - PHP SQL IF NOT EXISTS 将不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40747663/

相关文章:

mysql - 在 mysql 中打印\G 时出现问题。?

mysql - 生成级数序列,显示得分最高的 n 个候选者和得分第二高的 n+5 个候选者,依此类推

mysql - 复杂查询,许多连接

c# - 插入并返回插入的行数(非重复)和记录的 ID(新的或重复的)

mysql - Redis vs Mysql 引擎类型内存

mysql - 将参数传递给 MySQL 脚本命令行

php - 顺序和选择子句中的 Full Group BY 错误

php - 从 iPhone 应用程序调用远程 php 函数

php - PDO 插入成功但没有?

mysql - 如何将 MySQL count(*) 与 Order by 子句和 limit 一起使用?