计算我的mysql表中一行的更新次数

时间:2009-05-05 04:07:30

标签: php mysql

我有一个简单的mysql数据库,并使用此PHP代码进行更新。

mysql_query("REPLACE INTO `$db_table` (username, live, datetime, ip) 
VALUES ('$username', '1', '$timeofentry', '$ip')");

我使用REPLACE INTO和“username”上的主键,让用户将自己置于最新列表的顶部...

我想添加一个凹凸计数。条目更新(或“替换为”)的次数。

我将如何做到这一点?

非常感谢!

3 个答案:

答案 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;