从排序数组中删除重复项(传送门) 题目: 给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。...不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。...} } number+=1; return number; } } 题目剖析: 关键点有几个:排序数组(已排序),原地删除...首先,前面一段,直接判断当数组长度为0的时候,则直接返回0. 其次,当数组正常情况下(即数组是已经排序好了的。)。那么就需要处理多余的数组里的值。
从排序数组中删除重复项 给定一个有序数组,你需要原地删除其中的重复内容,使每个元素只出现一次,并返回新的长度。 不要另外定义一个数组,您必须通过用 O(1) 额外内存原地修改输入的数组来做到这一点。...示例: 给定数组: nums = [1,1,2], 你的函数应该返回新长度 2, 并且原数组nums的前两个元素必须是1和2 不需要理会新的数组长度后面的元素 要求在原地修改,同时是有序数组 定义一个长度标识...var size = 0 记录不重复元素的位置 遍历数组,当数组元素 nums[i] 和 nums[size] 相等时,说明该数字重复,不予处理,不相等是,使size + 1。...(Swift中已经废弃了++运算符,所以在使用 size += 1 代替。...开始用Swift学习算法中,在LeetCode中开始做初级算法这一章节,将做的题目在此做个笔记吧。
leetcode explore 初级算法第一题:从排序数组中删除重复项。...i++) { print(nums[i]); } 一大片的英文字母… 我们来提练下题目的意思: 1、输入:是一个列表,同时是一个 sorted array nums,即排好序的列表,并且列表中只包含数字...array,两者意思是等价的 3、注意看 Clarification 这段话,它说明了题目的另一个要求,和 in-place 是一致的,即题目虽然输出是一个数字,但会去检查函数传入的那个列表,要求它的前 n 项必须依次是不重复的数字
class Solution(object): def removeDuplicates(self, nums): """ ...
ID,Name,Sex 1 张三,男 2 张三,男 3 李四,女 4 李四,女 5 王五,男 --查找出最小行号ID的重复记录 select Name,Sex,Count(1),Mix(ID) into...#TempTable from Users group by Name,Sex having Count(1)>1 --删除重复记录,只保留最小行号的 Delete from Users from Users...IDB.ID --注意上面表中ID为自增长,如果User表中没有ID自增长,可以虚拟一个ID自增长列。
,返回的是不满足条件的所有数据 order_by是排序,参数是排序字段 aggregate聚合,参数是聚合类,返回的是一个字典 count没有参数,返回查询结果的数量,返回是一个数字 1.2条件查询 注意...:可以写多个查询条件,默认是且的关系 对应get,filter,exclude参数中可以写查询条件 格式:属性名__条件名=值 1.3F对象 用于查询时字段之间的比较 from django.db.models...|filter(多类名__字段__条件=值) 查英雄:多类.objects.filter(外键属性__字段__条件=值) 2.查询集 注意:对于queryset类的对象,可以继续调用之前的任何一个查询函数...,下一次再使用这个查询集的时候,使用的是Django之前存储的结果。...使用: 1、在配置文件中设置配置项MEDIA_ROOT=‘上传文件的保存目录’ 2、定义模型类时,图片字段的类型使用’imageField’ 3、迁移生成表,并在admin.py注册模型类,直接登录admin
这份指南描述了通过Django查询来生成和返回聚合值的方法。 整篇指南我们都将引用以下模型。这些模型用来记录多个网上书店的库存。...第一种方法是从整个查询集生成统计值。比如,你想要计算所有在售书的平均价钱。Django的查询语法提供了一种方式描述所有图书的集合。...与默认排序或order_by()交互 在查询集中的order_by() 部分(或是在模型中默认定义的排序项) 会在选择输出数据时被用到,即使这些字段没有在values() 调用中被指定。...这是因为默认排序项中的 name也是一个分组项,所以这个查询会根据非重复的 (data, name) 进行分组,而这并不是你本来想要的结果。...这个行为与查询集文档中提到的 distinct() 一样,而且生成规则也一样:一般情况下,你不想在结果中由额外的字段扮演这个角色,那就清空排序项,或是至少保证它仅能访问 values()中的字段。
删除 查询对象->对象.delete() 或者: 模型类.objects.filter(...).delete() 查询 模型类.objects.查询函数 查询相关函数: 函数名称 参数 作用 返回值...all 无 查询模型类对应表格中的所有数据 QuerySet(查询集) get 查询条件 查询满足条件一条且只能有一条数据 模型类对象,查不到会报错DoesNotExist filter 查询条件 返回满足条件的所有数据...QuerySet(查询集) exclude 查询条件 返回不满足条件的所有数据 QuerySet(查询集) order_by 排序字段 对查询结果进行排序 QuerySet(查询集) aggregate...= 值 可以写多个查询条件,默认是且的关系 F对象: 用于查询时字段之间的比较 from django.db.models import F Q对象: 用于查询时条件之间的逻辑关系 from django.db.models...使用 1.在配置文件中设置配置项MEDIA_ROOT='上传文件的保存目录' 2.定义模型类时,图片字段的类型使用 ImageField 3.迁移生成表并在admin.py注册模型类,直接登录Admin
,模型的对象不存在时会引发此异常,结合try/except使用 实例方法 str (self):重写object方法,此方法在将对象转换成字符串时会被调用 delete():将模型对象从数据表中删除 11...模型类的查询 查询集表示从数据库中获取的对象集合 查询集可以含有零个、一个或多个过滤器 过滤器基于所给的参数限制查询的结果 从Sql的角度,查询集和select语句等价,过滤器像where和limit子句...接下来主要讨论如下知识点 查询集 字段查询:比较运算符,F对象,Q对象(1)模型类查询集合 在管理器上调用过滤器方法会返回查询集 查询集经过过滤器筛选后返回新的查询集,因此可以写成链式过滤 惰性执行:..."异常 count():返回当前查询的总条数 first():返回第一个对象 last():返回最后一个对象 exists():判断查询集中是否有数据,如果有则返回True 限制查询集,如果获取一个对象...,但是如果这部分不在缓存中,那么接下来查询返回的记录将不会被缓存,这意味着使用索引来限制查询集将不会填充缓存,如果这部分数据已经被缓存,则直接使用缓存中的数据 比较运算符:表示两个下划线,左侧是属性名称
从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet。...Django不支持负索引,只能曲线救国。 6. distinct() distinct(*fields) 去除查询结果中重复的行。 默认情况下,QuerySet不会去除重复的行。....]> 如果有多个字段,传递flat将发生错误。 如果不传递任何值给values_list(),它将返回模型中的所有字段,以在模型中定义的顺序。 常见的情况是获取某个模型实例的特定字段值。...当最初获取数据时不知道是否需要这些特定字段的情况下,如果正在使用查询集的结果,可以告诉Django不要从数据库中检索它们。...QuerySet中的所有对象,并返回删除的对象个数和每个对象类型的删除次数的字典。
删除记录是指删除数据库中的一条或多条记录 删除单个MyModel对象或删除一个查询结果集(QuerySet)中的全部对象都是调用 delete()方法 删除单个对象 步骤 查找查询结果对应的一个数据对象...print(删除失败) 删除查询结果集 步骤 查找查询结果集中满足条件的全部 QuerySet 查询集合对象 调用查询集合对象的 delete () 方法实现删除 示例: # 删除全部作者中,年龄大于65...,从而得出总计值 (也可以是平均值或总和),即为查询集的每一项生成聚合。...特殊字段参数【必须项】: on_delete models.CASCADE 级联删除。...… 其它参请参考文档 https://docs.djangoproject.com/en/2.2/ref/models/fields/#foreignkey 其余常用的字段选项【非必须项】;如: null
每个模型有多个 类的属性变量,而每一个类的属性变量又都代表了数据库表中的一个字段 字段:每个字段通过Field类的一个实例表示 —— 例如字符字段CharField和日期字段 DateTimeField...也可以使用一条语句创建并保存一个对象,使用create()方法 查询对象 通过模型中的管理器构造一个查询集,来从你的数据库中获取对象。 查询集(queryset)表示从数据库中取出来的对象的集合。...它可以含有零个、一个或者多个过 滤器。过滤器基于所给的参数限制查询的结果。 从SQL 的角度,查询集和SELECT 语句等 价,过滤器是像WHERE 和LIMIT 一样的限制子句。...如果您在某些情 况下使用查询集的结果,当您最初获取数据时不知道是否需要这些特定字段,可以告诉 Django不要从数据库中检索它们。...User.objects.defer("username", "email") 删除对象 删除对象使用delete()。这个方法将立即删除对象且没有返回值。
,实际却删除了三条,因为我们删除的这本书在Book_authors表中有两条相关信息,这种删除方式就是django默认的级联删除。...# reverse(): 对查询结果反向排序 # distinct(): 从返回结果中剔除重复纪录 # values_list...aggregate()中每一个参数都指定一个包含在字典 from django.db.models import Avg,Min,Sum,Max 从整个查询集生成统计值。...是Book模型中price字段的平均值 aggregate()是QuerySet 的一个终止子句,意思是说,它返回一个包含一些键值对的字典。...,从而得出总计值(也可以是平均值或总和),即为查询集的每一项生成聚合。
/templates 在settings.py中TEMPLATE配置项 BACKEND:指定模板引擎 DIRS:模板的搜索目录(可以是一个或多个) APP_DIRS:是否在应用中的templates文件夹中搜索末班文件...) 等价于 条件查询 返回值:QuerySet,存放模型实例 exclude(条件) 语法同上 等价于 WHERE NOT 作用:返回不包含此条件的全部数据集 电商取非可以用该语句...字典 分组聚合 其实是为了实现Having语句 通过计算查询结果中每一个对象所关联的对象集合,从而得出总计值,为查询集的每一项生成聚合 QuerySet.annotate(结果变量名(别名)=聚合函数...,可避免重复进行复杂查询,提升效率。...中间件中的大部分方法返回None则表示进入下一项时间,返回HttpResponse则被拦截。
exclude(**kwargs) 返回一个包含对象的集合,它们不满足参数中所给的条件。 查询参数(上面函数定义中的**kwargs)需要满足特定的格式,字段检索一节中会提到。...一般来说,对 QuerySet 切片会返回新的 QuerySet – 这个过程中不会对运行查询。不过也有例外,如果你在切片时使用了 “step” 参数,查询集就会被求值,就在数据库中运行查询。...举个例子,使用下面这个这个查询集返回前十个对象中的偶数次对象,就会运行数据库查询: >>> Entry.objects.all()[:10:2] 要检索单独的对象,而非列表 (比如 SELECT foo...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。...它运行时立即删除对象而不返回任何值。例如: e.delete() 你也可以一次性删除多个对象。每个 QuerySet 都有一个 delete() 方法,它一次性删除 QuerySet 中所有的对象。
aggregate() 是一个 查询集 的未端子句,调用后会返回一个由名称-值配对组成的字典。名称是指统计的名称,值就是统计的值。名称由字段名称配双下划线加上函数名自动组成。...第二种方法是为 查询集 中每个独立的对象生成统计。...两个查询都会返回至少有一本好书(评分大于 3.0 )的出版商。但是,第一个查询中的统计会提供出版商的所有书的数量;第二个查询中的统计只返回好书的数量。...但是,当使用 values 子句来约束要统计的列时,返回的结果会有所不同。原先统计结果中,统计字段的值相同的项会分组合并统计。...')) 这个例子中会把作者按名字分组统计,返回的结果中不会有重复的作者名字。
Author.objects.annotate(sum_price=Sum("book__price")).values("name", "sum_price") 上去 4.查询集 查询集表示从数据库中获取的对象集合...,在管理器上调用某些过滤器方法会返回查询集,查询集可以含有零个、一个或多个过滤器。...过滤器基于所给的参数限制查询的结果,从Sql的角度,查询集和select语句等价,过滤器像where和limit子句。 返回查询集的过滤器如下: all():返回所有数据。...在新建的查询集中,缓存为空,首次对查询集求值时,会发生数据库查询,django会将查询的结果存在查询集的缓存中,并返回请求的结果,接下来对查询集求值将重用缓存中的结果。...限制查询集 可以对查询集进行取下标或切片操作,等同于sql中的limit和offset子句。 注意:不支持负数索引。 对查询集进行切片后返回一个新的查询集,不会立即执行查询。
(4)unique 如果该值设置为 True, 这个数据字段的值在整张表中必须是唯一的 (5)choices 由二元组组成的一个可迭代对象(例如,列表或元组),用来给字段提供选择项。...(): 从返回结果中剔除重复纪录 count(): 返回数据库中匹配查询(QuerySet)的对象数量。 ...用于聚合查询 所在位置:django.db.models 1.Avg:返回所给字段的平均值 2.Count:根据所给关联字段返回被关联model的数量。...3.Max:返回所给字段的最大值 4.Min:返回所给字段的最小值 5.Sum:计算所给字段值的总和 F查询与Q查询 F查询 在上面所有的例子中,我们构造的过滤器都只是将字段值与某个常量做比较。...它运行时立即删除对象而不返回任何值。例如: ? 1 e.delete() 你也可以一次性删除多个对象。
, 删除数据的时候先删除从表的数据,再删除主表的数据。...Django有两种过滤器用于筛选记录: filter:返回符合筛选条件的数据集 exclude :返回不符合筛选条件的数据集 链式调用: 多个filter和exclude可以连接在一起查询 Person.objects.filter...cls(p_name=p_name,p_age=p_age) person = Person.create('zs') 8.查询集 概念:查询集表示从数据库获取的对象集合,查询集可以有多个过滤器...过滤器:过滤器就是一个函数,基于所给的参数限制查询集结果,返回查询集的方法称为过滤器。 查询经过过滤器筛选后返回新的查询集,所以可以写成链式调用。...,会发生数据缓存,django会将查询出来的数据做 一个缓存,并返回查询结果,以后的查询直接使用查询集的缓存。
filter返回的是一个QuerySet对象,filter里可以设定多个过滤条件 4、查 查询数据使用QuerySet API。...reverse() 对查询结果反向排序 distinct() 从返回结果中剔除重复记录 values_list(*field)...根据日期获取查询集 datetimes() 根据时间获取查询集 none() 创建空的查询集 union() 并集 intersection...查找的参数(**kwargs)应该满足下文字段查找中的格式。多个参数之间是和AND的关系。 ...Django不支持负索引。 6.distinct(): distinct(*fields) 去除查询结果中重复的行。 默认情况下,QuerySet不会去除重复的行。
领取专属 10元无门槛券
手把手带您无忧上云