0

让我们简化一下:我有一个名为 chat 的表,其中有很多行,每个用户都可以添加一条新消息,这意味着表可以变得非常大。

(我在网上看过,有些例子不是很“清楚”。)

我需要删除所有旧消息,只保留 25 条最新消息。现在我希望通过 id 来实现,因为我的 id 设置为自动递增。

这就是我所拥有的,但它不起作用:

DELETE FROM `chat` ORDER BY `id` DESC LIMIT 0,50

我找到并更改了它,但没有运气!

我只是不确定要尝试什么。我不是很有经验,我知道基础知识,非常感谢任何帮助。

4

2 回答 2

1

保存 50 条记录:

DELETE FROM `chat`
WHERE id NOT IN (
  SELECT id
  FROM (
    SELECT id
    FROM `chat`
    ORDER BY id DESC
    LIMIT 50
  ) foo
);
于 2015-03-19T12:14:40.740 回答
0

我在评论中看到了你的 php 代码并编辑了我的答案,如果你正在寻找这个,它正在工作......要删除所有旧行,保留 25 个最新行,只需首先从你的聊天表中选择所有记录,然后计算相同,估计你的限制,即从计数中减去 25,然后,在聊天表上运行删除,但按 DESC 顺序,并给出通过从计数中减去 25 来估计的限制。

   $sqli = "SELECT * FROM chat";
  $result = $conn->query($sqli); 
  $count = count($result);
  $limit = $count - 25;
  //echo $limit;
   $sql = "DELETE FROM chat ORDER BY id DESC LIMIT $limit";
   if ($conn->query($sql) === TRUE)
   { 
   echo "true"; 
   } 
   else
    {
        echo "false";

   }
于 2015-03-19T12:19:12.407 回答