gpt4 book ai didi

sqlite - 限制 SQLite 中表中的记录数

转载 作者:行者123 更新时间:2023-12-03 15:57:09 25 4
gpt4 key购买 nike

我想在 SQLite 中实现一个最多存储 100 条记录的表。

我正在寻找的行为是该表存储记录,当它已满并添加新记录时,它会删除最旧的记录并写入新记录。

我正在阅读 SQLite 文档,但没有找到我要找的东西。

有任何想法吗?

编辑:对不起,我忘了解释一些重要的事情。每条记录都有一个 ID AUTOINCREMENT 字段。这就是我如何知道哪些记录是首先写入的。

我真的想不出如何只存储 100 条记录的解决方案。

最佳答案

对于小表,无论如何不建议您指定键,因此默认情况下它是在 rowid 上索引的。
因此 rowid 定义了添加记录的顺序。

对于添加的每一行:SELECT rowid FROM TheTable limit 1;并删除它!
简单本身。
IE。
delete from TheTable where rowid in (SELECT rowid FROM TheTable limit 1);
因此,对于在前端添加的每个记录,您在后端删除第一条记录。

对于具有一个或多个索引的表,只需忽略它们并使用 rowid 排序。
delete from TheTable where rowid in (SELECT rowid FROM TheTable order by rowid asc limit 1);
回答这个问题让我可以使用这种技术来改变我自己的项目,以限制“最近使用”文件列表中的文件数量。

关于sqlite - 限制 SQLite 中表中的记录数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31803682/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com