任务需求:项目中有个问题表,存储所有的问题,以_id为编号,由于_id未做唯一校验,所以早期数据有多个问题使用同一编号的情况。
需求就是找出编号有重复的数据,只保留第一个
开始之前
使用了values和annotate两个函数
简单的来说values可以理解成展示models指定列的值
annotate起到了group by的作用,
所以我做的事就是对指定字段按个数进行统计,然后留下重复编号的数据,进行清洗
看看数据库数据
查看每条数据的_id的值
对_id数据条数进行统计
转换数据格式为list
Emmm。。。我只需要重复数据,所以把_id唯一的数据剔除
写个简单的遍历
然后只需要找到这些数据,对每个_id只留下第一条数据
导出sql,做个备份,开始删除数据
最终处理:
删除过程:
再回到网站看看数据清洗后的效果
补充知识:django中annotate的一点使用方法
annotate 使用方法:
有时候我们需要连接两个表做一些查询,比如博客中有两个模型,一个文章模型,一个分类模型,分类模型是文章中的分类字段的外键,如果我们需要查询每个分类下文章的数量,最简单的方法就是先将所有分类查到:
categories = NewsCategory.objects.all()
文章模型名称为News
然后每个分类django都会自动给你添加一个属性category.news_set,这个方法就可以拿到分类对应的文章,然后category.news_set.count()就可以拿到每个分类有多少个文章了。
但是这个方法很低级啊,如果想高级一点,查询性能更优化,annotate了解一下
现在就可以对上面的查询方法进行优化了。
categories = NewsCategory.objects.annotate(num_count=Count('news'))
annotate中其实是给categories(Queryset)添加了一个属性,Queryset中的每个对象都会有这么一个属性
现在可以这样查询分类下的文章数量:
category.num_count()
将代码贴出来
原先的代码:
def cms_news_category(request): categories = NewsCategory.objects.all() context = { 'categories': categories } return render(request, 'cms/category.html', context=context) 模板category.html中的代码: {% for category in categories %} <td>{{ category.name }}</td> <td>{{ category.news_set.count }}</td> {% endfor %}
使用annotate后的代码:
def cms_news_category(request): categories = NewsCategory.objects.annotate(num_count=Count('news')) context = { 'categories': categories } return render(request, 'cms/category.html', context=context) 模板category.html中的代码: {% for category in categories %} <td>{{ category.name }}</td> <td>{{ category.num_count }}</td> {% endfor %}
以上这篇django ORM之values和annotate使用详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]