使用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列的情况下才适用(它对列仍然可以正常使用
INTEGERPRIMARY KEY)。无论如何,这应该更便携/更可靠:
SELECt foo FROM bar WHERe _ROWID_ >= (abs(random()) % (SELECt max(_ROWID_) FROM bar))LIMIT 1;
ROWID,
_ROWID_并且
OID都是SQLite内部行ID的别名。



