DUPLICATE KEY UPDATE
wird mit INSERT
verwendet und nicht mit UPDATE
Anweisung DOCS
Zählung für eine IP wird so aussehen
SELECT COUNT(*) FROM profiles WHERE IP = "127.1.0.0";
[Wenn Sie nicht nach dem suchen, was ich oben geschrieben habe]
wenn die IP-Adresse Ihr Primärschlüssel ist, dann
INSERT INTO
profiles (ip,views)
VALUES ("127.1.0.0",1)
ON DUPLICATE KEY
UPDATE views=views+1;
Wenn Sie möchten, dass Ihr Code richtig funktioniert, [verwenden Sie nicht mysql_* und entkommen Sie auch der Benutzereingabe]
<?php
require_once 'db_conx.php';
$result = mysql_query( "SELECT * FROM profiles WHERE pid =2") or die (mysql_error());
/*ON DUPLICATE KEY UPDATE mviews = mviews+ 1 */
if(mysql_num_rows($result) == 0){
mysql_query( "INSERT INTO profiles (views) value(1) ") or die (mysql_error());
}else {
mysql_query( "UPDATE profiles SET mviews = mviews +1 WHERE pid = '2' ") or die (mysql_error());
}
mysql_close($con);
?>