如果user_id在表中是唯一的,则插入记录,如果不是更新列

时间:2015-02-09 15:45:30

标签: php mysql pdo insert insert-update

如果user_id在表map中是唯一的,我需要INSERT记录,但如果没有,那么UPDATE那行user_id =:user_id with data ...

我尝试了什么:

  try {

      $result = $db->prepare('SELECT user_id FROM map WHERE user_id=:user_id');
      $result->bindParam(':user_id', $user_id); 
      $result->execute();

    //echo $jsonTable;
    } catch(PDOException $e) {
        echo 'ERROR: ' . $e->getMessage();
    }
           try {   
               if ($result==null) {
               $STH = $db->prepare("INSERT INTO map (json, user_id) VALUES (:json, :user_id)");

                $STH->bindParam(':json', $_POST['mapData']);
                $STH->bindParam(':user_id', $user_id);
                $STH->execute();
               } else {
                $STH = $db->prepare("UPDATE map SET json = :json WHERE user_id= :user_id");

                $STH->bindParam(':json', $_POST['mapData']);
                $STH->bindParam(':user_id', $user_id);
                $STH->execute(); 
               }
            } catch (PDOException $e) {
                echo $e->getMessage();
            }
            echo "<p>Data submitted successfully</p>";

        }

所以在这里我尝试检查是user_id我需要在表中添加exists,如果没有user_id,那么如果准备好user_id是new,那么我尝试插入数据,但是如果user_id alredy激发到表中然后更新那个记录...

但这对我不起作用,也不给我任何错误?

我开始使用php,很抱歉琐碎的问题......谢谢!

更新: 我也尝试插入,但如果user_id重复,则更新为:

        try {        
         $STH = $db->prepare("INSERT INTO map (user_id, json) VALUES (:user_id,:json)
on duplicate key update json=values(json)");


                $STH->bindParam(':json', $_POST['mapData']);
                $STH->bindParam(':user_id', $user_id);

                $STH->execute();

            } catch (PDOException $e) {
                echo $e->getMessage();
            }
            echo "<p>Data submitted successfully</p>";
    }

1 个答案:

答案 0 :(得分:0)

要检查唯一性,您可以使用唯一键来检查数据库的唯一性:http://dev.mysql.com/doc/refman/5.6/en/mysql-indexes.html

或者更好的是,ususally id是表的主键,这意味着您不必担心唯一性,主键始终是唯一的,db会为您检查