[py]django的manytomany字段和后台搜索过滤功能
我本来想搞下Django之select_related和prefetch_related的区别,看到这里有djangoapi的知识, 之前搞过django restfulapi,http://blog.csdn.net/iiiiher/article/details/77435615 ,算是搞起来了吧, 模块还不是很熟悉,djangorestframework, 快速的开放了接口给前端.
文章-属于某个分类-拥有多个标签: foreignkey&manytomany
看下models的manytomany和foreignkey
参考Django之select_related和prefetch_related
pip install djangorestframework 的官网
stratproject learnapi
startapp app01
models.py
class Category(models.Model):
name = models.CharField(max_length=30, verbose_name="类名") #修改字段名显示
creat_time = models.DateTimeField(auto_now_add=True, verbose_name="添加时间")
class Meta:#表名显示
verbose_name = "分类"
verbose_name_plural = verbose_name
def __str__(self): #xxx添加成功
return u'%s' % self.name
class Tag(models.Model):
name = models.CharField(max_length=30, verbose_name="标签名")
creat_time = models.DateTimeField(auto_now_add=True, verbose_name="添加时间")
class Meta:
verbose_name = "标签"
verbose_name_plural = verbose_name
def __str__(self):
return u'%s' % self.name
class Post(models.Model):
title = models.CharField(max_length=255, verbose_name="标题")
slug = models.SlugField(max_length=300, allow_unicode=True, unique=True, verbose_name="小标题")
content = models.TextField(verbose_name="文章内容")
publish_time = models.DateTimeField(auto_now_add=True, verbose_name="发布时间")
category = models.ForeignKey(Category, on_delete=models.CASCADE, verbose_name="分类")
tag = models.ManyToManyField(Tag, blank=True, verbose_name="标签")
class Meta:
verbose_name = "文章"
verbose_name_plural = verbose_name
def __str__(self):
return u'%s' % self.title
修改app名显示
app名-table名-字段名
- app01/__init__.py
default_app_config = "app01.apps.App01Config"
- apps.py
class App01Config(AppConfig):
name = 'app01'
verbose_name = u"文章"
注册app下的table到后台
list_display list_filter search_fields
from django.contrib import admin
from .models import Category, Tag, Post
# Register your models here.
class CategoryAdmin(admin.ModelAdmin):
list_display = ('name', 'creat_time') #后台展示这些列
class TagAdmin(admin.ModelAdmin):
list_display = ('name', 'creat_time')
class PostAdmin(admin.ModelAdmin):
list_display = ('title', 'publish_time', 'category') #后台展示这些列
list_filter = ('category',) # 分类筛选
search_fields = ('title', 'slug', 'content',)#后台索引这些字段搜索
#注册app
admin.site.register(Category, CategoryAdmin)
admin.site.register(Tag, TagAdmin)
admin.site.register(Post, PostAdmin)


list_filter字段是外键的情况写法 字段名__外键

todo:
select_related和prefetch_related的区别
链式关系逻辑栗子1: 课程-章节-视频: 还有一种是链式的一对多关系
譬如 course里有多个章节, 一个章节lesson里有多个,一个lesson里有多个video

from datetime import datetime
from django.db import models
# Create your models here.
class Courses(models.Model):
name = models.CharField(max_length=50, verbose_name="课程名")
desc = models.CharField(max_length=300, verbose_name="课程描述")
detail = models.TextField(verbose_name="课程详情")
degree = models.CharField(choices=(("cj", "初级"), ('ZJ', "中级"), ("GJ", "高级")), verbose_name="课程等级")
learn_times = models.IntegerField(default=0, verbose_name="学习时长(分钟)")
students = models.IntegerField(default=0, verbose_name="学习人数")
fav_nums = models.IntegerField(default=0, verbose_name="收藏人数")
image = models.ImageField(max_length=100, upload_to="courses/%Y/%m/", verbose_name="封面图")
click_nums = models.IntegerField(default=0, verbose_name="点击数")
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间")
class Meta:
verbose_name = "课程"
verbose_name_plural = verbose_name
class Lesson(models.Model):
course = models.ForeignKey(Courses, verbose_name="课程") # 看在哪个表添加外键,就看我需要你,就在我里面添加ForeignKey
name = models.CharField(max_length=100, verbose_name="章节名")
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间")
class Meta:
verbose_name = "章节"
verbose_name_plural = verbose_name
class Video(models.Model):
lesson = models.ForeignKey(Lesson, verbose_name="章节")
name = models.CharField(max_length=100, verbose_name="章节名称")
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间")
class Meta:
verbose_name = "视频"
verbose_name_plural = verbose_name
class CourseResourse(models.Model):
course = models.ForeignKey(Courses, verbose_name="课程名")
name = models.CharField(max_length=100, verbose_name="资源名称")
download = models.FileField(upload_to="course/resource/%Y/%m", verbose_name="资源文件下载地址", max_length=100)
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间")
class Meta:
verbose_name = "课程资源"
verbose_name_plural = verbose_name
链式关系逻辑栗子2: 城市-课程机构-教师
城市-课程机构-教师
两种为模型添加时间字段的方法
- 方法1,用自带的auto_now_add
class Category(models.Model):
name = models.CharField(max_length=20, verbose_name="分类")
create_time = models.DateTimeField(auto_now_add=True, verbose_name="添加时间")
- 方法2,用py模块
class Article(models.Model):
title = models.CharField(max_length=50, verbose_name="标题")
content = models.TextField(verbose_name="内容")
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间")
继续定制admin页面
list_editable: 修改数据
class PostAdmin(admin.ModelAdmin):
list_display = ['title', 'category', 'add_time', ]
search_fields = ['title', 'category', ]
list_filter = ['title', 'category', 'add_time', ]
list_display_links = None # 必须有这个,否则报错: # which cannot be used unless 'list_display_links' is set.
list_editable = ['title', 'category', ]

加上后方便编辑数据了:

filter_horizontal = ['tag', ]

支持分页了
class PostAdmin(admin.ModelAdmin):
list_display = ['title', 'category', 'add_time', ]
search_fields = ['title', 'category', ]
list_filter = ['title', 'category', 'add_time', ]
list_display_links = None
list_editable = ['title', 'category', ]
filter_horizontal = ['tag', ]
list_per_page = 2

支持排序了
class PostAdmin(admin.ModelAdmin):
list_display = ['title', 'category', 'add_time', ]
search_fields = ['title', 'category', ]
list_filter = ['title', 'category', 'add_time', ]
list_display_links = None
list_editable = ['title', 'category', ]
filter_horizontal = ['tag', ]
list_per_page = 2
ordering = ('-add_time',) # 这里我逆序排列

[py]django的manytomany字段和后台搜索过滤功能的更多相关文章
- YII关联字段并带搜索排序功能
1.简介 从接触yii框架到现在已经快有两个月了,但是自己对yii框架的了解程度并不是很深,并没有系统地去学习,仅仅只是在做项目的时候遇到不懂得知识才去翻手册. 在上一个项目中因为需要将关联的表的字段 ...
- DRF:过滤&搜索&排序功能
过滤功能利用的是第三方包 django_filters,搜索和排序利用的是 Django DRF 提供的 filters 示例代码如下: from rest_framework import filt ...
- 在使用django admin的后台搜索时报错
在使用django admin的后台搜索时报错 百度说在search_fields中定义了非字符串字段,最后发现author引用了外键 解决办法: 有外健时应写成: 本表外键字段__外键所在表所需要查 ...
- Django之model admin自定义后台管理
Admin管理界面是django的杀手级应用.它读取你模式中的元数据,然后提供给你一个强大而且可以使用的界面,网站管理者可以用它立即向网站中添加内容. 比如,数据表如下: from django.db ...
- Django ormmodel模型字段参考文章
Model 字段参考 (Model field reference)¶ 本文档包含所有 字段选项 (field options) 的内部细节和 Django 已经提供的 field types . 参 ...
- django学习-19.admin管理后台的配置和登录
目录结构 1.前言 2.admin管理后台的配置和登录的完整操作流程 2.1.第一步: 在[settings.py]里对常量[INSTALLED_APPS]的值进行相关配置 2.2.第二步: 在[ur ...
- Django的Many-to-Many(多对多)模型
Django的Many-to-Many(多对多)模型 日期:2012-05-05 | 来源:未知 | 作者:redice | 人围观 | 1 人鼓掌了! 鲲鹏Web数据抓取 - 专业Web ...
- 四、Django之模型与管理后台-Part 2
一.数据库安装 打开mysite/settings.py配置文件,这是整个Django项目的设置中心.Django默认使用SQLite数据库,因为Python源生支持SQLite数据库,所以你无须安装 ...
- django项目后台权限管理功能。
对后台管理员进行分角色,分类别管理,每个管理员登录账号后只显示自己负责的权限范围. 创建后台管理数据库 models.py文件内 # 管理员表 class Superuser(models.Model ...
随机推荐
- mysql压力测试工具Mysqlslap
mysql 性能测试工具:The MySQL Benchmark Suite(不支持多CPU而且不是压力工具) 压力测试工具: MySQL super-smack:需要找能连接外网的机器,能连接外网的 ...
- 查看当前mysql数据库实例中,支持的字符集有哪些,或者是否支持某个特定字符集
需求描述: 查看当前mysql实例中支持哪些字符集,过滤特定的字符集 操作过程: 1.通过show character set来进行查看 mysql> show character set; + ...
- mybatis由浅入深day02_课程复习_1订单商品数据模型分析
mybatis第二天 高级映射 查询缓存 和spring整合 课程复习: mybatis是什么? mybatis是一个持久层框架,mybatis是一个不完全的ORM框架.sql语句需要程序员自己去编 ...
- Java精选笔记_集合【List(列表)接口】
List(列表)接口 简介 List接口继承自Collection接口,是单列集合的一个重要分支,习惯性地会将实现了List接口的对象称为List集合. 元素是有序的,即元素的存入顺序和取出顺序一致, ...
- day01<计算机基础知识&Java语言基础>
计算机基础知识(计算机概述) 计算机基础知识(软件开发和计算机语言概述) 计算机基础知识(人机交互) 计算机基础知识(键盘功能键和快捷键) 计算机基础知识(如何打开DOS控制台) 计算机基础知识(常见 ...
- ios开发之--UICollectionView的使用
最近项目中需要实现一种布局,需要用到UICollectionView,特在此整理记录下! 贴上最终实现的效果图: 1,声明 @interface FirstViewController ()<U ...
- GIS-008-ArcGIS JS API 全图
//待服务加载完成后,设置视野范围到全图范围 layer.on('load', function () { var extent = map.getLayer(map.layerIds[0]).ful ...
- linux命令之用户和用户组
知识点: 1.-rwx--x--x (711) 只有所有者才有读,写,执行的权限,组群和其他人只有执行的权限 2.将root用户添加到supergroup用户组 groupadd supergroup ...
- MySQL性能优化(四)-- MySQL explain详解
前言 MySQL中的explain命令显示了mysql如何使用索引来处理select语句以及连接表.explain显示的信息可以帮助选择更好的索引和写出更优化的查询语句. 一.格式 explain + ...
- Anfroid 在界面中显示图片 ImageView
ImageView1.什么是ImageView是显示图片的一个控件2.ImageView属性android:src ImageView的内容颜色 android:background ImageVie ...