MySQL和PHP:循环遍历表查找值(如果存在)更新如果不插入新值

时间:2014-07-01 12:37:43

标签: javascript php mysql

我的数据库中的表格如下所示:

http://abload.de/img/bildschirmfoto2014-07osj75.png

我需要php中的一个函数循环遍历表并在“Translations”列中找到提交的值,如果该值已经存在,它应该更新Count值+1,如果没有插入新行。

我希望有人可以帮助我,因为我的PHP技能并不是最好的。

这是我到目前为止所尝试的:

Javascript代码:

var insertNewTranslation = function(word, translation) { 
    console.log("DBController, " +word+ " " + translation);

        $.ajax({
        type: 'GET',
        url: 'themes/tagging-theme/php/insertTranslation.php',
        data: {
                aktuelleswort: translation,
                uebersetzung: word
                },
        dataType: 'json',
        success : function(data){
            var tableNamen = data;
            console.log(tableNamen)



        },
        error : function(XMLHttpRequest, textStatus, errorThrown) {
            console.log("XMLHttpRequest", XMLHttpRequest);
            console.log("textStatus", textStatus);
            console.log("errorThrown", errorThrown);    
        }
    });

};

php文件如下所示:

<?php  
if( isset($_POST['aktuelleswort']) ) {
     $table=$_POST['aktuelleswort'];
}
else {
     $table="default";
}
if( isset($_POST['uebersetzung']) ) {
     $translation=$_POST['uebersetzung'];
}
else {
     $translation="default";
}


$con = mysql_connect('localhost', 'root', 'root');
if (!$con)
{
  die('Could not connect: ' . mysql_error());
}

mysql_select_db("bayerisches_lexikon", $con);

$sql = "SELECT _id, Translations, Count FROM $table";

$result = mysql_query($sql) OR die(mysql_error());
while ($row = mysql_fetch_assoc($result))
    $uebersetzungen[] = $row;

// mysql_query("INSERT INTO `bayerisches_lexikon`.`$table` (`Translations`, `Count`) 
//   VALUES ('" . $translation . "', '" . $count . "');");

mysql_close($con);

?>

2 个答案:

答案 0 :(得分:0)

您需要在&#34;翻译&#34;上设置一个唯一键。柱。然后使用

insert into mytable (translations, count) values ('gewurztraminer',1) on duplicate key update count=count+1

根本不是php。

答案 1 :(得分:0)

mysqli_num_rows()

您将使用上述功能;如果它返回0你将执行INSERT;如果没有,你将进行更新。