php – MYSQL插入或更新(如果存在于单向复合主键表中)
发布时间:2020-12-13 22:48:55 所属栏目:PHP教程 来源:网络整理
导读:我在用户之间有一个友情表,看起来像这样. 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
我在用户之间有一个友情表,看起来像这样.
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专家. 感谢您的反馈. 解决方法
根据您的描述,您似乎只保持“最新”的关系.如果是这种情况,为什么不首先删除关系,然后插入新关系?
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |