我本来想搞下Django之select_related和prefetch_related的区别,看到这里有djangoapi的知识, 之前搞过django restfulapi,http://blog.csdn.net/iiiiher/article/details/77435615 ,算是搞起来了吧, 模块还不是很熟悉,djangorestframework, 快速的开放了接口给前端.

django api测试

django后台admin

文章-属于某个分类-拥有多个标签: 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字段和后台搜索过滤功能的更多相关文章

  1. YII关联字段并带搜索排序功能

    1.简介 从接触yii框架到现在已经快有两个月了,但是自己对yii框架的了解程度并不是很深,并没有系统地去学习,仅仅只是在做项目的时候遇到不懂得知识才去翻手册. 在上一个项目中因为需要将关联的表的字段 ...

  2. DRF:过滤&搜索&排序功能

    过滤功能利用的是第三方包 django_filters,搜索和排序利用的是 Django DRF 提供的 filters 示例代码如下: from rest_framework import filt ...

  3. 在使用django admin的后台搜索时报错

    在使用django admin的后台搜索时报错 百度说在search_fields中定义了非字符串字段,最后发现author引用了外键 解决办法: 有外健时应写成: 本表外键字段__外键所在表所需要查 ...

  4. Django之model admin自定义后台管理

    Admin管理界面是django的杀手级应用.它读取你模式中的元数据,然后提供给你一个强大而且可以使用的界面,网站管理者可以用它立即向网站中添加内容. 比如,数据表如下: from django.db ...

  5. Django ormmodel模型字段参考文章

    Model 字段参考 (Model field reference)¶ 本文档包含所有 字段选项 (field options) 的内部细节和 Django 已经提供的 field types . 参 ...

  6. django学习-19.admin管理后台的配置和登录

    目录结构 1.前言 2.admin管理后台的配置和登录的完整操作流程 2.1.第一步: 在[settings.py]里对常量[INSTALLED_APPS]的值进行相关配置 2.2.第二步: 在[ur ...

  7. Django的Many-to-Many(多对多)模型

      Django的Many-to-Many(多对多)模型 日期:2012-05-05 |  来源:未知 |  作者:redice |  人围观 |  1 人鼓掌了! 鲲鹏Web数据抓取 - 专业Web ...

  8. 四、Django之模型与管理后台-Part 2

    一.数据库安装 打开mysite/settings.py配置文件,这是整个Django项目的设置中心.Django默认使用SQLite数据库,因为Python源生支持SQLite数据库,所以你无须安装 ...

  9. django项目后台权限管理功能。

    对后台管理员进行分角色,分类别管理,每个管理员登录账号后只显示自己负责的权限范围. 创建后台管理数据库 models.py文件内 # 管理员表 class Superuser(models.Model ...

随机推荐

  1. tiny6410nfs挂载问题

    一.制作根文件系统 1.下载最新版的 busybox 地址:http://www.busybox.net/downloads/ 2.编译busybox.先make menuconfig ,修改以下:B ...

  2. swift - UISlider 的用法

    swift的UISlider的用法和oc基本没有区别 1.创建 class SecondViewController: UIViewController { var slider = UISlider ...

  3. laravel 使用 vue (gulp)

    1)首先要安装 gulp 看这里 http://www.cnblogs.com/tujia/p/6397779.html 2)编辑js 默认 laravel 里有一个 /resources/asset ...

  4. laravel 社会化(联合)登录扩展包(QQ、微信、微博等)

    laravel的官方包只支付国外网站的联合登录:http://laravelacademy.org/post/6288.html 国内用户的话,可以用这个:https://github.com/ove ...

  5. python远程登录服务器(paramiko模块安装和使用)

    转自:http://www.jb51.net/article/46285.htm 一:简介 由paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器 ...

  6. 如何使用css影藏滚动条

    1.单纯的一句代码: div ::-webkit-scrollbar {width: 0px;}//或者display:none 但是这代码最大的弊端就是只能在webkit内核的浏览器上进行显示,无法 ...

  7. Mybatis返回map集合

    <resultMap id="pieMap" type="HashMap"> <result property="value&quo ...

  8. mysql增删改查基本语句

    mysql的增删改查属于基本操作,又被简称CRUD,其中删用的较少,毕竟这个功能给用户是是非常危险的,就是客户删除的数据也没有真正的删除,其中查询是十分常用的. 1 mysql数据库增加:create ...

  9. 使用OpenRowSet操作Excel Excel导入数据库

    使用 OpenRowSet 和 OpenDataSource 访问 Excel 97-2007 测试文件:D:\97-2003.xls和D:\2007.xlsx,两个文件的内容是一模一样的. 测试环境 ...

  10. Map集合中value()方法与keySet()、entrySet()区别 《转》

    在Map集合中 values():方法是获取集合中的所有的值----没有键,没有对应关系, KeySet(): 将Map中所有的键存入到set集合中.因为set具备迭代器.所有可以迭代方式取出所有的键 ...