ZBLOG

peewee mysql 随机查询数据并分页

以下是使用Peewee和MySQL进行随机查询数据并分页的示例代码:

  1. import random
  2. from peewee import *
  3. from models import MyModel # 假设已经定义了模型
  4. # 连接到MySQL数据库
  5. mysql_db = MySQLDatabase('mydatabase', user='myuser', password='mypassword',
  6. host='localhost', port=3306)
  7. # 定义每页显示的记录数和当前页码
  8. PAGE_SIZE = 10
  9. page_num = 1
  10. # 随机选取数据并分页
  11. query = MyModel.select().order_by(fn.Random())
  12. total_count = query.count()
  13. offset = (page_num - 1) * PAGE_SIZE
  14. query = query.offset(offset).limit(PAGE_SIZE)
  15. # 执行查询并打印结果
  16. for row in query:
  17. print(row.id, row.name, row.age)
  18. # 输出分页信息
  19. total_page = (total_count + PAGE_SIZE - 1) // PAGE_SIZE
  20. print(f"第{page_num}/{total_page}页,共{total_count}条记录")

在上面的示例中,我们首先连接到MySQL数据库,然后使用 fn.Random() 函数对查询结果进行随机排序。然后,我们计算出总记录数和当前页的偏移量,并使用 offset()limit() 方法进行分页。最后,我们遍历查询结果并打印每条记录的 id、name 和 age 字段。

同时,我们还输出了分页信息,包括总页数、当前页码和总记录数。

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=1851

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?