Hello! 欢迎来到小浪云!


删除题目后,如何保证自动抽题系统中题目数量和数据库 ID 一致?


avatar
小浪云 2024-11-09 53

删除题目后,如何保证自动抽题系统中题目数量和数据库 ID 一致?

删除自动生成主键 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 变化的影响,始终可以确保抽取到有效题目。

相关阅读