开发者社区> 问答> 正文

SQLite-ORDER BY RAND()?mysql

在MySQL中,我可以使用RAND()函数,SQLite 3中还有其他选择吗?

展开
收起
保持可爱mmm 2020-05-17 13:47:49 382 0
1 条回答
写回答
取消 提交回答
  • 使用random():

    SELECT foo FROM bar WHERE id >= (abs(random()) % (SELECT max(id) FROM bar)) LIMIT 1; 编辑(按QOP):由于SQLite Autoincrement ed列上的文档指出:

    只要您从不使用最大ROWID值并且从未删除具有最大ROWID的表中的条目,上述常规ROWID选择算法将生成单调递增的唯一 ROWID。如果您曾经删除行,那么在创建新行时,可能会重复使用先前删除的行中的ROWID。

    上面的内容只有在没有INTEGER PRIMARY KEY AUTOINCREMENT列的情况下才适用(它对列仍然可以正常使用INTEGER PRIMARY KEY)。无论如何,这应该更便携/更可靠:

    SELECT foo FROM bar WHERE ROWID >= (abs(random()) % (SELECT max(ROWID) FROM bar)) LIMIT 1; ROWID,_ROWID_并且OID都是SQLite内部行ID的别名。来源:stack overflow

    2020-05-17 13:53:19
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
搭建电商项目架构连接MySQL 立即下载
搭建4层电商项目架构,实战连接MySQL 立即下载
PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

相关镜像