首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL | 如何对查询结果集进行排序

数据操作语言:结果集排序 如果没有设置,查询语句不会对结果集进行排序。也就是说,如果想让结果集按照某种顺序排列,就必须使用 ORDER BY 子句。 SELECT .........ASC 代表升序(默认),DESC 代表降序 如果排序列是数字类型,数据库就按照数字大小排序,如果是日期类型就按日期大小排序,如果是字符串就按照字符集序号排序。...默认情况下,如果两条数据排序字段内容相同,那么排序会是什么样子?...type);SHOW INDEX FROM t_message;ALTER TABLE t_message ADD INDEX idx_type(type);SQL 我们可以使用 ORDER BY 规定首要排序条件和次要排序条件...数据库会先按照首要排序条件排序,如果遇到首要排序内容相同的记录,那么就会启用次要排序条件接着排序。

6.3K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    django 1.8 官方文档翻译: 2-5-4 聚合 (初稿)

    annotate()子句的返回结果是一个查询集 (QuerySet);这个 QuerySet可以用任何QuerySet方法进行修改,包括 filter(), order_by(), 甚至是再次应用annotate...例如,根据一本图书作者数量的多少对查询集 QuerySet进行排序: >>> Book.objects.annotate(num_authors=Count('authors')).order_by('...不是在原始的 QuerySet返回结果中对每个对象中添加注解,而是根据定义在values() 子句中的字段组合对先结果进行唯一的分组,再根据每个分组算出注解值, 这个注解值是根据分组中所有的成员计算而得的...这是因为默认排序项中的 name也是一个分组项,所以这个查询会根据非重复的 (data, name) 进行分组,而这并不是你本来想要的结果。...这个行为与查询集文档中提到的 distinct() 一样,而且生成规则也一样:一般情况下,你不想在结果中由额外的字段扮演这个角色,那就清空排序项,或是至少保证它仅能访问 values()中的字段。

    1.7K30

    Django篇(二)

    order_by: 对查询的结果进行排序,返回类型也是QuerySet。 以下我们以模型类为stuinfo是实例。...2、缓存 当我们使用同一个查询集的时候,只有第一次是执行到数据库,然后把结果储存起来,当我们再次使用这个查询集的时候,就会调用我们缓存中的数据。...查询集相当于一个列表,我们取值可以遍历取出,也可以进行下表或者切片取出。 当我们对一个查询集进行切片或下标查询,会返回一个新的查询集。 不同的是我们的切片不允许为负值。 判断一个查询集是否有数据。...查询集.exists(),有返回True,没有返回False 模型类关系 1、一对多关系 例如一个班级对应多个人 我们需要用ForeignKey()来关联我们的模型。...同样我们可以不使用Django帮我们生成的,我们可以自己创建一个。 为什么要自己创建? 1、过滤查询集,比如你查询全部数据,我只让你返回前十条。

    1.4K20

    推荐 11 个 GitHub 上比较热门的 Java 项目

    具有如下特性: ● 创建独立的Spring应用程序 ● 嵌入的Tomcat,无需部署WAR文件 ● 简化Maven配置 ● 自动配置Spring ● 提供生产就绪型功能,如指标,健康检查和外部配置 ● 绝对没有代码生成和对...XML没有要求配置 6 smartTable https://github.com/huangyanbin/smartTable Star 1200 ?...9 JavaScript 控件 TableView https://github.com/evrencoskun/TableView Star 1218 TableView是一个用于显示数据表格的JavaScript...控件,集成的分页控件,可对表格中的数据集进行客户端分页,亦可对表格中的数据集进行客户端排序,JavaScript 控件: ● TableView(数据表格控件), 可配置标题, 计数, 行复选框, 过滤器..., 分页, 排序, 多选 ● PagerView(分页控件) ● SortView(排序控件) 10 elasticsearch https://github.com/elastic/elasticsearch

    1.1K20

    推荐11个GitHub上比较热门的Java项目

    具有如下特性: ● 创建独立的Spring应用程序 ● 嵌入的Tomcat,无需部署WAR文件 ● 简化Maven配置 ● 自动配置Spring ● 提供生产就绪型功能,如指标,健康检查和外部配置 ● 绝对没有代码生成和对...XML没有要求配置 6 smartTable https://github.com/huangyanbin/smartTable Star 1200 ?...10 JavaScript 控件 TableView https://github.com/evrencoskun/TableView Star 1218 TableView是一个用于显示数据表格的JavaScript...控件,集成的分页控件,可对表格中的数据集进行客户端分页,亦可对表格中的数据集进行客户端排序,JavaScript 控件: ● TableView(数据表格控件), 可配置标题, 计数, 行复选框, 过滤器..., 分页, 排序, 多选 ● PagerView(分页控件) ● SortView(排序控件) 11 elasticsearch https://github.com/elastic/elasticsearch

    1.1K20

    Django框架学习(四)

    ,返回的是不满足条件的所有数据 order_by是排序,参数是排序字段 aggregate聚合,参数是聚合类,返回的是一个字典 count没有参数,返回查询结果的数量,返回是一个数字 1.2条件查询 注意...order_by 1.7关联查询 1、查询和指定对象关联的数据(重点掌握) 由一查多:一对象.多类名小写__set.all() 由多查一:多对象.外键属性 2、通过模型类进行关联查询 查图书:一类.objects.get...True代表有,False代表没有。...两大特性: 1、惰性查询:只有在使用查询集中的数据时才会进行数据库真正查询操作 2、查询结果的缓存:如果使用同一个查询集时,只有在第一次使用查询集时会进行数据库的查询操作,然后Django框架就会把查询的结果存起来...,下一次再使用这个查询集的时候,使用的是Django之前存储的结果。

    1.5K41

    django模型

    每个模型对 应数据库中唯一的一张表 如何编写模型 模型:每个模型都用一个类表示,该类继承自django.db.models.Model。...最后的结果仍然是一个查询集,它包含标题以”What“开 头、发布日期在2005年1月30日至当天之间的所有记录 过滤后的查询集是独立的 每次你筛选一个查询集,得到的都是全新的另一个查询集,它和之前的查询集之间没有任何绑...你可以将过滤器保持一整 天,直到查询集 需要求值时,Django 才会真正运行这个查询。...这个异常是正在查询的模型类的一个属性 —— 所以在上面的代码中, 如果没有主键为1 的Entry 对象,Django 将引发一个Entry.DoesNotExist。...这个方法将立即删除对象且没有返回值。

    3.1K20

    iOS开发之表视图爱上CoreData

    那么TableView为什么会爱上CoreData呢?下面会通个代码给出他们相爱的原因。就举一个IOS开发中的经典的demo:通讯录来说明问题。...2.CoreData准备的差不多啦,该我们的TableView出场啦,在Empty Application中默认的时没有storyboard, 如果你又想通过storyboard来简化你的操作,得给应用创建一个...和CoreData相爱的过程啦,如何在storyboard中对TableView的cell进行配置在这儿就不赘述了,下面给出我们要通过TableView和CoreData来实现什么功能。     ...中显示还需要通过CoreData把我们的存储在sqlite中的数据来查询出来,再用CoreData给我们提供的方法把查询结果做一个转换,转换成适合TableView显示的数据,下面给出相应的获取数据的代码...因此TableView深爱着CoreData. 上面我们完成了通过CoreData来对数据的插入和查询并同步到TableView中,下面将会介绍到如何对我们的Cell进行删除。

    2.2K80

    Django学习笔记之Django ORM Aggregation聚合详解

    在当今根据需求而不断调整而成的应用程序中,通常不仅需要能依常规的字段,如字母顺序或创建日期,来对项目进行排序,还需要按其他某种动态数据对项目进行排序。Djngo聚合就能满足这些要求。...联合聚合Joins and aggregates 目前为止,我们聚合查询的field都属于我们要查询的Model,我们也可以用其它Model的field来进行聚合查询,例如: >>> from django.db.models...但是第一个查询的注解包含其该出版商发行的所有图书的总数;而第二个查询的注解只包含出版过好书的出版商的所发行的好书(评分大于3分)总数。在第一个查询中,注解在过滤器之前,所以过滤器对注解没有影响。...就不是在原始的 QuerySet 返回结果中对每个对象中添加注解,而是根据定义在 values() 从句中的字段组合对先结果进行唯一的分组,再根据每个分组算出注解值,这个注解值是根据分组中所有的成员计算而得的...这是因为默认排序项中的name也是一个分组项,所以这个查询会根据非重复的(data,name)进行分组,而这并不是你本来想要的结果。

    1.1K20

    Django之QuerySet详解

    可以使用下列方法对QuerySet提交查询操作: 迭代:QuerySet是可迭代的,在首次迭代查询集时执行实际的数据库查询。...exclude() 排除满足条件的对象 annotate() 使用聚合函数 order_by() 对查询集进行排序 reverse() 反向排序 distinct() 对查询集去重...换句话说,用order_by()方法对QuerySet对象进行操作会返回一个扩大版的新QuerySet对象。因此,使用多值字段对结果进行排序时要格外小心。 没有方法指定排序是否考虑大小写。...和get_or_create()一样,这个方法也容易导致竞态条件,如果数据库层级没有前置唯一性会让多行同时插入。 在Django1.11在defaults中增加了对可调用值的支持。...11. first() 返回结果集的第一个对象, 当没有找到时返回None。如果QuerySet没有设置排序,则将会自动按主键进行排序。

    2.4K20

    Django 数据统计查询

    每本书与每个作者之间是一个多对多的关系,我们要为每本书总结这个关系。 要产生每个对象的统计可以使用 annotate() 子句。...每本书与每个作者之间是一个多对多的关系,我们要为每本书总结这个关系。 要产生每个对象的统计可以使用 annotate() 子句。...第一个查询中统计先于过滤器,所以过滤器对统计没有作用。而第二个查询过滤器先于统计,所以统计的对象是已经过滤过的。 order_by() 统计可以作为排序的基础。...缺省排序或 order_by() 子句的副作用 一个查询集中 order_by() 子句中的字段(或一个模型中缺省排序字段)会对输了数据产生影响,即使在 values() 中没有这些字段的定义时也同样会影响...缺省排序或 order_by() 子句的副作用 一个查询集中 order_by() 子句中的字段(或一个模型中缺省排序字段)会对输了数据产生影响,即使在 values() 中没有这些字段的定义时也同样会影响

    2.3K20

    iOS中CoreData数据管理系列四——进行数据与页面的绑定

    iOS中CoreData数据管理系列四——进行数据与页面的绑定 一、引言     在上一篇博客中,我们讨论了CoreData框架中添加与查询数据的操作,事实上,在大多数情况下,这些数据都是由一个UITableView...表视图进行展示的,因此,CoreData框架中还未开发者提供了一个类NSFetchedResultsController,这个类作为桥接,将视图与数据进行绑定。...二、进行数据初始化     NSFetchedResultsController的初始化需要一个查询请求和一个数据操作上下文。...managedObjectContext:moc sectionNameKeyPath:nil cacheName:nil];     //设置代理     _fecCon.delegate=self;     //进行数据查询...三、与UITableView进行数据绑定  -(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath

    71910

    Django MVT之M

    在Django MVC概述和开发流程中已经讲解了Django的MVT开发流程,本文重点对MVT中的模型(Model)进行重点讲解。 配置MySQL数据库 确保已经安装了操作mysql的包。...QuerySet对象 参数为查询条件。 exclude 返回表中不满足条件的数据。 QuerySet对象 参数为查询条件。 order_by 对查询结果进行排序。...缓存: 当使用的是同一个查询集时,第一次使用的时候会发生实际数据库的查询,然后把结果缓存起来,之后再使用这个查询集时,使用的是缓存中的结果。...可以对一个查询集进行取下标或切片操作,切片操作会产生一个新的查询集。与python的列表不同的是,下标不允许为负数。...# 1.自定义一个管理器类,这个类继承models.Manger类 class SchoolInfoManager(models.Manager): # 过滤父类方法返回的查询集来改变查询集

    1K10

    查询集 QuerySet和管理器Mana

    order_by():对结果进行排序。...对查询集可以再次调用过滤器进行过滤,如 BookInfo.objects.filter(bread__gt=30).order_by('bpub_date') 从SQL的角度讲,查询集与select语句等价...() 继续执行遍历迭代操作后,才真正的进行了数据库的查询 for book in qs: print(book.btitle) 2>缓存 使用同一个查询集,第一次使用时会发生数据库的查询,然后Django...会把结果缓存下来,再次使用这个查询集时会使用缓存的数据,减少了数据库的查询次数。...对查询集进行切片后返回一个新的查询集,不会立即执行查询 如果获取一个对象,直接使用[0],等同于[0:1].get(),但是如果没有数据,[0]引发IndexError异常,[0:1].get()如果没有数据引发

    1.1K40
    领券