我有一个简单的mysql数据库,并使用此PHP代码进行更新。
mysql_query("REPLACE INTO `$db_table` (username, live, datetime, ip)
VALUES ('$username', '1', '$timeofentry', '$ip')");
我使用REPLACE INTO和“username”上的主键,让用户将自己置于最新列表的顶部...
我想添加一个凹凸计数。条目更新(或“替换为”)的次数。
我将如何做到这一点?
非常感谢!
答案 0 :(得分:2)
首先,您需要在表中添加另一列以保持计数。
其次,您应该使用UPDATE语句而不是REPLACE。
REPLACE实际上会删除该行,然后插入一个效率不高的新行。
UPDATE `$db_table` SET datetime = NOW(), ip = '$IP',
bumpCount = bumpCount + 1 WHERE username = '$username' LIMIT 1;
答案 1 :(得分:2)
您可以使用INSERT ... ON DUPLICATE KEY UPDATE执行现有行的实际更新。
$mysql = mysql_connect(..
...
$username = mysql_real_escape_string(...
$ip = mysql_real_escape_string(...
...
$query = "
INSERT INTO
`$db_table`
(username, live, datetime, ip)
VALUES
(
'$username',
'1',
'$timeofentry',
'$ip'
)
ON DUPLICATE KEY UPDATE
ip = '$ip',
bumpCount = bumpCount + 1
";
$result = mysql_query($query, $mysql);
答案 2 :(得分:0)
@dot
您将bumpCount字段定义为表格中的另一列。我建议也将它设置为默认值。
然后您的表定义有时会像:
CREATE TABLE my_table
(username varchar(255) not null primary key,
live int,
datetime datetime not null,
ip varchar(15) not null,
bumpCount int unsigned not null default 1);
您的插入/更新将类似于:
INSERT INTO my_table (username,live,datetime,ip)
VALUES
('$username',1,now(),'$ip')
ON DUPLICATE KEY UPDATE datetime=now() ip='$ip', bumpCount=bumpCount + 1;