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

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了php – MYSQL插入或更新(如果存在于单向复合主键表中)脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
我在用户之间有一个友情表,看起来像这样.

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是指向另一个表的指针,该表定义用户具有的关系类型(friendship(1),pending(2)或blocked(3))

如果用户1是用户2的朋友,我只有一个实例| 1 | 2 | 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)

由于表的性质,我无法使用INSERT … ON DUPLICATE KEY UPDATE.

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

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

感谢您的反馈.

解决方法

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

脚本宝典总结

以上是脚本宝典为你收集整理的php – MYSQL插入或更新(如果存在于单向复合主键表中)全部内容,希望文章能够帮你解决php – MYSQL插入或更新(如果存在于单向复合主键表中)所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。