dspym82000 2015-05-04 16:36 采纳率: 100%
浏览 21
已采纳

选择所有MySQL行并重新插入

So I have a table in my database which has some 1000 rows in it.

Now I don't want to display these records in the same order they are inserted into the table.

I want all the rows in the table to be somehow randomly shuffled. Ex : if I have 10 records in the order 1 2 3 4 5 6 7 8 9 10, I want it like 8 2 4 6 3 1 7 9 10 5.

The rand() method can be used but it's not efficient for large data. I can fetch the data and shuffle in PHP but I don't want to use it because then I would have to shuffle it every time I fetch the data.

So basically I don't want to shuffle and fetch the data but shuffle all the rows in table itself.

Just once shuffling my rows in table is more than enough for me.

  • 写回答

1条回答 默认 最新

  • dongwu3747 2015-05-04 16:43
    关注

    You create a second table, duplicating the original structure, then dump all the records into it. Rename the tables and you're done. It'd be worth rebuilding any indexes on the new table and you might hit a few snags with mySql getting fussy about re-using old names.

    INSERT INTO <copy of source table>
    SELECT *
    FROM <source table>
    ORDER BY RAND()
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测