数据操作语言:结果集排序 如果没有设置,查询语句不会对结果集进行排序。也就是说,如果想让结果集按照某种顺序排列,就必须使用 ORDER BY 子句。 SELECT .........ASC 代表升序(默认),DESC 代表降序 如果排序列是数字类型,数据库就按照数字大小排序,如果是日期类型就按日期大小排序,如果是字符串就按照字符集序号排序。...默认情况下,如果两条数据排序字段内容相同,那么排序会是什么样子?...type);SHOW INDEX FROM t_message;ALTER TABLE t_message ADD INDEX idx_type(type);SQL 我们可以使用 ORDER BY 规定首要排序条件和次要排序条件...数据库会先按照首要排序条件排序,如果遇到首要排序内容相同的记录,那么就会启用次要排序条件接着排序。
方法一:order_by 排序 # 更新时间字段,倒序排序 articles = Article.objects.filter(show_status=True).order_by('-time_created...') # 更新时间字段,正序排序 articles = Article.objects.filter(show_status=True).order_by('time_created') # 更新时间字段...,正序排序 articles = Article.objects.order_by('time_created') 也可以使用两个字段进行排序,当 第一个字段值 相等时,再用 第二个 字段值 来排序 articles...time_updated", ] 或 admin.py class ArticleAdmin(admin.ModelAdmin): ordering = ["time_updated", ] 每次查询数据库都会默认使用该字段来排序...,除非你显示的使用 order_by 语句来排序
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()中的字段。
order_by: 对查询的结果进行排序,返回类型也是QuerySet。 以下我们以模型类为stuinfo是实例。...2、缓存 当我们使用同一个查询集的时候,只有第一次是执行到数据库,然后把结果储存起来,当我们再次使用这个查询集的时候,就会调用我们缓存中的数据。...查询集相当于一个列表,我们取值可以遍历取出,也可以进行下表或者切片取出。 当我们对一个查询集进行切片或下标查询,会返回一个新的查询集。 不同的是我们的切片不允许为负值。 判断一个查询集是否有数据。...查询集.exists(),有返回True,没有返回False 模型类关系 1、一对多关系 例如一个班级对应多个人 我们需要用ForeignKey()来关联我们的模型。...同样我们可以不使用Django帮我们生成的,我们可以自己创建一个。 为什么要自己创建? 1、过滤查询集,比如你查询全部数据,我只让你返回前十条。
运行程序,发现没法选多行了 三、排序 1. 排序下拉框没内容 当前这个下拉框里面是没东西的,运行的时候点没反应 2. 补充相关函数和调用 3....去数据库里面查,发现数据还在 为什么没删掉,没有submit 4. 添加保存和取消代码 5....,要对tableview里面数据的修改进行限制 2....自定义代理组件 tableview默认的单元格编辑组件是QlineEdit,对输入的数据无法限制。可以为某列设置自定义代理组件,比如QcommoBox。...数据库语句没有排序字段,所以新纪录出现在最后
具有如下特性: ● 创建独立的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
具有如下特性: ● 创建独立的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
,返回的是不满足条件的所有数据 order_by是排序,参数是排序字段 aggregate聚合,参数是聚合类,返回的是一个字典 count没有参数,返回查询结果的数量,返回是一个数字 1.2条件查询 注意...order_by 1.7关联查询 1、查询和指定对象关联的数据(重点掌握) 由一查多:一对象.多类名小写__set.all() 由多查一:多对象.外键属性 2、通过模型类进行关联查询 查图书:一类.objects.get...True代表有,False代表没有。...两大特性: 1、惰性查询:只有在使用查询集中的数据时才会进行数据库真正查询操作 2、查询结果的缓存:如果使用同一个查询集时,只有在第一次使用查询集时会进行数据库的查询操作,然后Django框架就会把查询的结果存起来...,下一次再使用这个查询集的时候,使用的是Django之前存储的结果。
q.execBatch()) //进行批处理,如果出错就输出错误 qDebug() << q.lastError(); 第三:QSqlQueryModel类 只读数据模型为数据库结果集 1...使QSqlQueryModel类 创建的数据库能读写,继承QAbstractItemModel类 刚开始我们就讲到,这个模型默认是只读的,所以我们在窗口上并不能对表格中的内容进行修改。...,和排序 1. ...(); model->setFilter(QObject::tr(“name = ‘%1′”).arg(name)); //根据姓名进行筛选 model->select(); //显示结果 4.排序操作...在Qt中的QSqlRelationalDelegate委托类就能实现这个功能 ui->tableView->setItemDelegate(new QSqlRelationalDelegate(ui->
排序 使用order_by对结果进行排序 # 默认升序 >>> BookInfo.objects.all().order_by('readcount') 对结果进行排序。...对查询集可以再次调用过滤器进行过滤,如 >>> books = BookInfo.objects.filter(readcount__gt=30).order_by('pub_date') >>> books...使用同一个查询集,第一次使用时会发生数据库的查询,然后Django会把结果缓存下来,再次使用这个查询集时会使用缓存的数据,减少了数据库的查询次数。...对查询集进行切片后返回一个新的查询集,不会立即执行查询。
每个模型对 应数据库中唯一的一张表 如何编写模型 模型:每个模型都用一个类表示,该类继承自django.db.models.Model。...最后的结果仍然是一个查询集,它包含标题以”What“开 头、发布日期在2005年1月30日至当天之间的所有记录 过滤后的查询集是独立的 每次你筛选一个查询集,得到的都是全新的另一个查询集,它和之前的查询集之间没有任何绑...你可以将过滤器保持一整 天,直到查询集 需要求值时,Django 才会真正运行这个查询。...这个异常是正在查询的模型类的一个属性 —— 所以在上面的代码中, 如果没有主键为1 的Entry 对象,Django 将引发一个Entry.DoesNotExist。...这个方法将立即删除对象且没有返回值。
那么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进行删除。
在当今根据需求而不断调整而成的应用程序中,通常不仅需要能依常规的字段,如字母顺序或创建日期,来对项目进行排序,还需要按其他某种动态数据对项目进行排序。Djngo聚合就能满足这些要求。...联合聚合Joins and aggregates 目前为止,我们聚合查询的field都属于我们要查询的Model,我们也可以用其它Model的field来进行聚合查询,例如: >>> from django.db.models...但是第一个查询的注解包含其该出版商发行的所有图书的总数;而第二个查询的注解只包含出版过好书的出版商的所发行的好书(评分大于3分)总数。在第一个查询中,注解在过滤器之前,所以过滤器对注解没有影响。...就不是在原始的 QuerySet 返回结果中对每个对象中添加注解,而是根据定义在 values() 从句中的字段组合对先结果进行唯一的分组,再根据每个分组算出注解值,这个注解值是根据分组中所有的成员计算而得的...这是因为默认排序项中的name也是一个分组项,所以这个查询会根据非重复的(data,name)进行分组,而这并不是你本来想要的结果。
可以使用下列方法对QuerySet提交查询操作: 迭代:QuerySet是可迭代的,在首次迭代查询集时执行实际的数据库查询。...exclude() 排除满足条件的对象 annotate() 使用聚合函数 order_by() 对查询集进行排序 reverse() 反向排序 distinct() 对查询集去重...换句话说,用order_by()方法对QuerySet对象进行操作会返回一个扩大版的新QuerySet对象。因此,使用多值字段对结果进行排序时要格外小心。 没有方法指定排序是否考虑大小写。...和get_or_create()一样,这个方法也容易导致竞态条件,如果数据库层级没有前置唯一性会让多行同时插入。 在Django1.11在defaults中增加了对可调用值的支持。...11. first() 返回结果集的第一个对象, 当没有找到时返回None。如果QuerySet没有设置排序,则将会自动按主键进行排序。
每本书与每个作者之间是一个多对多的关系,我们要为每本书总结这个关系。 要产生每个对象的统计可以使用 annotate() 子句。...每本书与每个作者之间是一个多对多的关系,我们要为每本书总结这个关系。 要产生每个对象的统计可以使用 annotate() 子句。...第一个查询中统计先于过滤器,所以过滤器对统计没有作用。而第二个查询过滤器先于统计,所以统计的对象是已经过滤过的。 order_by() 统计可以作为排序的基础。...缺省排序或 order_by() 子句的副作用 一个查询集中 order_by() 子句中的字段(或一个模型中缺省排序字段)会对输了数据产生影响,即使在 values() 中没有这些字段的定义时也同样会影响...缺省排序或 order_by() 子句的副作用 一个查询集中 order_by() 子句中的字段(或一个模型中缺省排序字段)会对输了数据产生影响,即使在 values() 中没有这些字段的定义时也同样会影响
2.3 排序 使用order_by对结果进行排序 BookInfo.objects.all().order_by('bread') # 升序 BookInfo.objects.all().order_by...order_by():对结果进行排序。...对查询集可以再次调用过滤器进行过滤,如 BookInfo.objects.filter(bread__gt=30).order_by('bpub_date') 也就意味着查询集可以含有零个、一个或多个过滤器...,第一次使用时会发生数据库的查询,然后Django会把结果缓存下来,再次使用这个查询集时会使用缓存的数据,减少了数据库的查询次数。...对查询集进行切片后返回一个新的查询集,不会立即执行查询。 示例:获取第1、2项,运行查看。 qs = BookInfo.objects.all()[0:2] ?
iOS中CoreData数据管理系列四——进行数据与页面的绑定 一、引言 在上一篇博客中,我们讨论了CoreData框架中添加与查询数据的操作,事实上,在大多数情况下,这些数据都是由一个UITableView...表视图进行展示的,因此,CoreData框架中还未开发者提供了一个类NSFetchedResultsController,这个类作为桥接,将视图与数据进行绑定。...二、进行数据初始化 NSFetchedResultsController的初始化需要一个查询请求和一个数据操作上下文。...managedObjectContext:moc sectionNameKeyPath:nil cacheName:nil]; //设置代理 _fecCon.delegate=self; //进行数据查询...三、与UITableView进行数据绑定 -(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath
在Django MVC概述和开发流程中已经讲解了Django的MVT开发流程,本文重点对MVT中的模型(Model)进行重点讲解。 配置MySQL数据库 确保已经安装了操作mysql的包。...QuerySet对象 参数为查询条件。 exclude 返回表中不满足条件的数据。 QuerySet对象 参数为查询条件。 order_by 对查询结果进行排序。...缓存: 当使用的是同一个查询集时,第一次使用的时候会发生实际数据库的查询,然后把结果缓存起来,之后再使用这个查询集时,使用的是缓存中的结果。...可以对一个查询集进行取下标或切片操作,切片操作会产生一个新的查询集。与python的列表不同的是,下标不允许为负数。...# 1.自定义一个管理器类,这个类继承models.Manger类 class SchoolInfoManager(models.Manager): # 过滤父类方法返回的查询集来改变查询集
exclude() 排除满足条件的对象 annotate() 使用聚合函数 order_by() 对查询集进行排序 reverse() 反向排序 distinct() 对查询集去重...dates() 根据日期获取查询集 datetimes() 根据时间获取查询集 none() 创建空的查询集 all() 获取所有的对象 union() 并集 intersection...() 交集 difference() 差集 select_related() 附带查询关联对象 prefetch_related() 预先查询 extra() 附加SQL查询...的aggregate和annotate方法属于高级查询方法,主要用于组合查询,是Django高手们必需要熟练掌握的。...当我们需要对查询集(queryset)的某些字段进行计算或进行先分组再计算或排序, 我们就需要使用aggregate和annotate方法了。
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()如果没有数据引发
领取专属 10元无门槛券
手把手带您无忧上云