[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 ...
随机推荐
- tiny6410nfs挂载问题
一.制作根文件系统 1.下载最新版的 busybox 地址:http://www.busybox.net/downloads/ 2.编译busybox.先make menuconfig ,修改以下:B ...
- swift - UISlider 的用法
swift的UISlider的用法和oc基本没有区别 1.创建 class SecondViewController: UIViewController { var slider = UISlider ...
- laravel 使用 vue (gulp)
1)首先要安装 gulp 看这里 http://www.cnblogs.com/tujia/p/6397779.html 2)编辑js 默认 laravel 里有一个 /resources/asset ...
- laravel 社会化(联合)登录扩展包(QQ、微信、微博等)
laravel的官方包只支付国外网站的联合登录:http://laravelacademy.org/post/6288.html 国内用户的话,可以用这个:https://github.com/ove ...
- python远程登录服务器(paramiko模块安装和使用)
转自:http://www.jb51.net/article/46285.htm 一:简介 由paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器 ...
- 如何使用css影藏滚动条
1.单纯的一句代码: div ::-webkit-scrollbar {width: 0px;}//或者display:none 但是这代码最大的弊端就是只能在webkit内核的浏览器上进行显示,无法 ...
- Mybatis返回map集合
<resultMap id="pieMap" type="HashMap"> <result property="value&quo ...
- mysql增删改查基本语句
mysql的增删改查属于基本操作,又被简称CRUD,其中删用的较少,毕竟这个功能给用户是是非常危险的,就是客户删除的数据也没有真正的删除,其中查询是十分常用的. 1 mysql数据库增加:create ...
- 使用OpenRowSet操作Excel Excel导入数据库
使用 OpenRowSet 和 OpenDataSource 访问 Excel 97-2007 测试文件:D:\97-2003.xls和D:\2007.xlsx,两个文件的内容是一模一样的. 测试环境 ...
- Map集合中value()方法与keySet()、entrySet()区别 《转》
在Map集合中 values():方法是获取集合中的所有的值----没有键,没有对应关系, KeySet(): 将Map中所有的键存入到set集合中.因为set具备迭代器.所有可以迭代方式取出所有的键 ...