删除自动生成主键 id 后如何解决数据库 id 问题?
问题:
在一个自动抽题系统中,数据库使用主键自增长,且系统提供了删除功能。在删除某些题目后,题目数量和数据库 id 之间出现不一致。如何解决此问题?
解决方案:
直接查询所有剩余的题目,然后从中随机选择即可。无需关注数据库 id 是否连续。例如:
select * from questions;
此查询将返回所有剩余的题目,然后您可以使用 random 函数从中随机选择一个,如下所示:
// 获取所有剩余题目 List<Question> questions = jdbcTemplate.query("SELECT * FROM questions", Question.class); // 从题目列表中随机选择一个 Question question = questions.get(new Random().nextInt(questions.size()));
这种方法不会受数据库 id 变化的影响,始终可以确保抽取到有效题目。
以上就是删除题目后,如何保证自动抽题系统中题目数量和数据库 ID 一致?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号