4

更新和回答感谢并感谢@ypercube

答案在下面,我冒昧地发布它,因为它出现在我的 PHP 中有一个助手,我正在使用 PDO

    INSERT INTO `users_relationship` (`profile_1_id`, `profile_2_id` ,`request_date`,`auth_token`,`status`, `updated`, `deleted`)
    VALUES
        (:uid, :fid, '$now', '$fToken', 0, '$now',0),
        (:fid, :uid, '$now', '$fToken', 0, '$now',0)
    ON DUPLICATE KEY UPDATE request_date = VALUES(request_date), auth_token = VALUES(auth_token), updated = VALUES(updated), deleted = VALUES (deleted);

我有一个令我困惑的 MySQL 查询,要求是我需要一次在表中创建行但是这些行可能已经存在,所以我需要更新这一行中的一些列而不是插入重复项。

例子

Justin (2) 与 Ben (5) 相关,然后通过更新数据库中 profile_1_id 为 2 或 5 的行并将标志插入到已删除列中来终止关系。Ben 然后尝试重新点燃关系,因此我们需要再次更新行并删除已删除的标志并更新 request_date、auth_token 并使用新值更新。

我写了以下内容,但它没有触发错误:

重复的列名“2012-09-05 10:13:06”

INSERT INTO `users_relationship` (`profile_1_id`, `profile_2_id`,`request_date`,`auth_token`,`status`, `updated`, `deleted`)
    SELECT * FROM 
        (SELECT 2, 5, '2012-09-05 10:13:06', 'SQLTEST', 0, '2012-09-05 10:13:06', 0) AS faTmp,
        (SELECT 5, 2, '2012-09-05 10:13:06', 'SQLTEST', 0, '2012-09-05 10:13:06', 0) AS fTmp
    WHERE NOT EXISTS 
        (SELECT  * FROM `users_relationship`WHERE `profile_1_id`=2 AND `profile_2_id` =5) OR 
        (SELECT  * FROM `users_relationship`WHERE `profile_1_id`=5 AND `profile_2_id` =2) LIMIT 1

我是在正确的道路上还是有更好的方法来做到这一点?

谢谢

贾斯汀

4

2 回答 2

6

最好的方法似乎是添加一个UNIQUE约束(profile_1_id, profile_2_id)然后使用:

INSERT INTO `users_relationship` 
  (`profile_1_id`, `profile_2_id`
  ,`request_date`,`auth_token`,`status`, `updated`, `deleted`)
VALUES
  (2, 5, '2012-09-05 10:13:06', 'SQLTEST', 0, '2012-09-05 10:13:06', 0),
  (5, 2, '2012-09-05 10:13:06', 'SQLTEST', 0, '2012-09-05 10:13:06', 0) 
ON DUPLICATE KEY UPDATE
  request_date = VALUES(request_date)          --- what you want to happen
, auth_token = VALUES(auth_token)              --- when rows exist
  --- ; 
于 2012-09-05T10:06:58.640 回答
1

你可以这样做,但语法是

 WHERE NOT EXISTS  
        (SELECT  * FROM `users_relationship`WHERE `profile_1_id`=2 AND `profile_2_id` =5) 
 AND  
 NOT EXISTS  
        (SELECT  * FROM `users_relationship`WHERE `profile_1_id`=5 AND `profile_2_id` =2)
于 2012-09-05T10:05:39.060 回答