最近实现的一个系统中,遇到了这样的情况:需要从数据库表中随机读取n条记录,必须保证每条记录都不相同原来的想法是弄两个链表,第一个读取对应数据库表中的所有记录,根据每个记录的ID来生成这个链表;第二个链表是有选定的随机读取的记录生成的,这样从第一个链表中选定的,就可以剪掉,以后就不会被选种,把选中的添加到第二个链表中后来发现,在不同的数据库中完全可以用SQL语句来实现随机选定不同记录这里把不同数据库实现的语句粘在这里,以供需要的人来参考Select a random row with MySQL:SELECT column FROM tableORDER BY RAND()LIMIT 1Select a random row with PostgreSQL:SELECT column FROM tableORDER BY RANDOM()LIMIT 1Select a random row with Microsoft SQL Server:SELECT TOP 1 column FROM tableORDER BY NEWID()Select a random row with IBM DB2:SELECT column, RAND() as IDX FROM table ORDER BY IDX FETCH FIRST 1 ROWS ONLYSelect a random record with Oracle:SELECT column FROM( SELECT column FROM tableORDER BY dbms_randomvalue )WHERE rownum = 1
不用从页面取id
去掉foreach
$sql="select from phome_ecms_wma order by rand() limit 30"
就行了
以上就是关于SQL语句如何实现从数据库表中查询随机数据的记录全部的内容,包括:SQL语句如何实现从数据库表中查询随机数据的记录、PHP随机从数据库读取N条数据、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)