文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

TortoiseORM-Order_By排序,你学会了吗?

2024-11-30 15:52

关注

Tortoise是一个基于异步IO的Python ORM库,受到Django ORM的启发。Tortoise ORM在设计上考虑到了关系,并且深受优秀而流行的Django ORM的影响。它的设计中注重的是你不仅仅是在处理表格,你是在处理关系型数据。用于操作关系型数据库,如MySQL、PostgreSQL等。在Tortoise中,可以使用order_by()方法对查询结果进行排序,该方法接受一个或多个字段名,可以按照这些字段进行升序或降序排列。

以下是order_by()方法的详细用法说明和示例:

用法说明

在Tortoise中,order_by()方法用于对查询结果进行排序。该方法可以接受一个或多个参数,每个参数表示一个字段名,用于指定排序的依据。字段名可以是模型类的属性名,也可以是数据库表中的列名。方法还可以使用-(减号)来表示降序排列。

pythonCopy codeawait Model.filter(...).order_by('field1', '-field2', 'field3')

上面的代码中,order_by()方法接受了三个参数,分别为field1、-field2和field3。其中,field1表示按照该字段升序排列,-field2表示按照该字段降序排列,field3表示按照该字段升序排列。如果order_by()方法没有指定任何参数,则返回的结果集将按照默认顺序排序,即按照主键升序排列。

示例

下面是一些使用Tortoise库order_by()方法的示例。

假设有一个User模型,用于存储用户信息。该模型包含id、name、age和created_at四个字段,其中id是主键。

pythonCopy codefrom tortoise import fields
from tortoise.models import Model

class User(Model):
id = fields.IntField(pk=True)
name = fields.CharField(max_length=50)
age = fields.IntField()
created_at = fields.DatetimeField(auto_now_add=True)

1、按照name字段升序排列。

pythonCopy codeusers = await User.filter(...).order_by('name')

2、按照age字段降序排列。

pythonCopy codeusers = await User.filter(...).order_by('-age')

3、按照created_at和name字段升序排列。

pythonCopy codeusers = await User.filter(...).order_by('created_at', 'name')

4、按照name字段升序排列,并限制返回结果的数量为10条。

pythonCopy codeusers = await User.filter(...).order_by('name').limit(10)

5、按照关联模型的列进行排序。

如果您有一个包含关联模型的模型,并且想按照关联模型的列对查询结果进行排序,可以使用双下划线(__)指定关联模型的列名。例如,假设您有一个名为Person的模型,其中包含一个名为age的列和一个名为country的列,country列关联一个名为Country的模型,Country模型包含一个名为name的列,您可以使用以下代码按照Country模型的name列对Person模型进行排序:

queryset = QuerySet(Person).order_by('country__name')

以上示例演示了Tortoise库order_by()方法的使用方法,可以根据需要灵活组合使用。

来源:今日头条内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯