DUPLICATE KEY UPDATE
används med INSERT
och inte med UPDATE
uttalande DOCS
räkna för en IP kommer att vara så här
SELECT COUNT(*) FROM profiles WHERE IP = "127.1.0.0";
[Om du inte letar efter det jag har skrivit ovan]
om IP-adress är din primära nyckel så
INSERT INTO
profiles (ip,views)
VALUES ("127.1.0.0",1)
ON DUPLICATE KEY
UPDATE views=views+1;
Om du vill att din kod ska fungera korrekt[använd inte mysql_* undvik också användarinmatning]
<?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);
?>