MYSQL插入或更新(如果存在于单向复合主键表上)

时间:2013-06-04 17:10:22

标签: php mysql insert insert-update

我在用户之间有一个友谊表,看起来像这样。

CREATE TABLE user_relations (
pkUser1 INTEGER UNSIGNED NOT NULL,
pkUser2 INTEGER UNSIGNED NOT NULL,
pkRelationsType TINYINT UNSIGNED NOT NULL,
PRIMARY KEY(pkUser1,pkUser2),
FOREIGN KEY(pkuser1) references users(ID),
FOREIGN KEY(pkuser2) references users(ID),
FOREIGN KEY(pkRelationsType) references user_relations_type(ID)
);

pkRelationsType是指向另一个表的指针,该表定义了用户的关系类型(友谊(1),待定(2)或被阻止(3))

如果用户1 用户2 的朋友,我只有一个实例|1|2|1| {{1 }}

问题是,为了阻止用户,我必须记住已经建立了关系(用户可能已经是朋友,甚至还有待处理的友情请愿),所以我试图插入数据或更新它如果这种关系不存在。

我有友情请求发送,但如果数据已经存在,则忽略插入。

|2|1|1|

由于表格的性质,我无法使用INSERT INTO user_relations(pkUser1,pkUser2,pkRelationsType) SELECT * FROM (SELECT :sender0,:target0,2) AS tmp WHERE NOT EXISTS (SELECT pkUser1 FROM user_relations WHERE (pkUser1= :sender1 AND pkUser2=:target1) OR (pkUser1=:sender2 AND pkUser1=:target2) LIMIT 1)

我一直在考虑用PHP处理它,搜索关系以及它的顺序(如果存在)然后做一件事或另一件事但似乎浪费了处理。

请注意,即使我到目前为止处理了自己,我也不是MYSQL专家。 希望我已经很好地解释了自己。

感谢您的反馈。

1 个答案:

答案 0 :(得分:1)

从您的描述中,您似乎只保持“最新”的关系。如果是这种情况,为什么不首先删除关系,然后插入新关系?