我正在编写一个分页API,通过设置随机种子值来提供随机结果。除非用户想要混洗结果,否则结果将是相同的,但如果用户想混洗,我将重新创建种子值,以便返回一组不同的记录。
我这里的问题是,如果我从数据库中删除一条记录,即使种子是相同的,结果也会因为元素长度的变化而不同。有没有办法让它即使在记录被删除之后也保持不变?
查询示例:
set seed to 0.1; select * from table order by random();发布于 2019-06-18 21:48:27
我不会按random()排序,因为它无法正确控制。
如果你想要一个可靠的,但看似随机的顺序,你可以使用散列函数:
SELECT * FROM atable ORDER BY hashint4(id);这在DELETE上是稳定的,因为散列值不会改变。
如果您需要不同的“随机”顺序,请以可重复的方式生成一个随机整数并使用
... ORDER BY hashint4(id + 42)https://stackoverflow.com/questions/56649606
复制相似问题