Django后台管理

基本配置

默认登录地址:http://127.0.0.1:8000/admin

创建后台管理员:

  python3  ./manage.py  createsuperuser    # 回车后输入以下内容

  Username:输入用户名

  Email Address:电子邮箱

  Password:密码
  Password(again):重复密码

基本管理

1、在应用中的admin.py中注册要管理的实体类(models.py中的类)

from django.contrib import admin
from .models import * # 注册CartInfo和Order两个实体类
admin.site.register(CartInfo)
admin.site.register(Order)

2、修改models.py,来改变后台内容的显示

  1). models.py中为各个类(实体类)追加一个方法。

def __str__(self):
return self.属性名

  2). 通过Models类的内部类Meta定义每个类的展现形式

class Author(models.Model):
  ... ...# 定义对象在后台的展现形式
def __str__(self):
return self.names # 声明内部类,定义当前类在管理页面中的展现形式
class Meta:
# 1.修改当前表名为author(需要同步到数据库)
db_table = 'author' # 下面两个只与后台有关系
# 2.修改实体类在后台管理页中的名称(单数)
verbose_name = '作者'
# 3.修改实体类在后台管理页中的名称(复数)
verbose_name_plural = verbose_name # 4.先按照年龄降序排序,再按照ID升序排序
ordering = ['-age', 'id']

高级管理

1、在admin.py中创建高级管理类并注册

# 定义Author高级管理类
# 类名:实体类名+Admin,必须继承admin.ModelAdmin
class AuthorAdmin(admin.ModelAdmin):
pass # 注册高级管理类
admin.site.register(Author, AuthorAdmin)

2、定制高级管理信息

# 定义Author高级管理类
class AuthorAdmin(admin.ModelAdmin):
# list_display:指定在列表页中能够显示的字段
# 取值:由属性名称组成的元组或列表
list_display = ['names', 'age', 'email'] # list_display_links:定义列表页中能链接到详情页的字段
# 取值:由属性名称组成的元组或列表(必须存在与list_display中)
list_display_links = ['names', 'email'] # list_editable:指定在列表页中允许被编辑的字段
# 取值:由属性名称组成的元组或列表
# 不能出现在list_display_links, 但是必须在list_display中
list_editable = ['age'] # search_fields:添加允许被搜索的字段
# 取值:由属性名称组成的元组或列表
search_fields = ['names', 'email'] # list_filter:在列表的右侧增加过滤器,实现快速筛选
list_filter = ['names', 'email'] # fields:指定详情页显示的字段以及排列的顺序
# 取值:由属性名称组成的元组或列表
fields = ['email', 'names', 'age', 'isActive'] # date_hierarchy:在列表页的顶端增加一个时间选择器
# 取值必须是DateField或DateTimeField的值
date_hierarchy = 'publicate' # fieldsets:在详情页中,对字段进行分组显示(不能同时与fields存在)
fieldsets = [
# 分组1
(
'基本信息', {
'fields': ('names', 'email')
}
),
# 分组2
(
'可选信息', {
'fields': ('age', 'isActive'),
'classes': ('collapse',),
}
)
]

关系映射

一对一映射

  一对一表示,A表中的一条记录只能与B表中的一条记录相关联。

  数据库中实现方式:

    A表:设置主键  

    B表:增加一列(字段),并引用自A表的主键,并且得增加唯一约束

  1、在Django中的实现方式:

    在要相关联的两个实体类中的任意一个中增加:

    属性(字段)名 =  models.OneToOneField(要关联的实体类名)

  2、关联查询

# 在Wife类中新增一个字段一对一关联Author类
class Wife(models.Model):
...
author=models.OneToOneField(Author)
# 正向查询:通过wife 找 author
# 1.获取 id 为1 的 Wife的信息
wife = Wife.objects.get(id=1)
# 2.通过 Wife 的关联属性 author 来找Author
author = wife.author # 反向查询:通过author 找 wife
# 1.获取 id 为14 的 Author的信息
author = Author.objects.get(id=14)
# 2.通过 author 的关联属性 wife 来找wife
# wife是Django通过OneToOneField在Author(被关联表)中默认增加的一个隐式属性
wife = author.wife

一对多映射

  一对多表示,A表中的一条记录能与B表中的多条记录相关联。反之,B表中的一条记录只能与B表中的一条记录相关联。

  数据库中实现方式:

    通过外键来实现一对多,在‘多’表中增加外键对‘一’表的主键进行引用

  1、在Django中的实现:

    在“多”的实体类中增加:

    属性(字段)名 = models.ForeignKey("一"的实体类名)

  2、关联查询

# Book(多) 和 Publisher(一)
class Book(models.Model):
... ...
publisher=models.ForeignKey(Publisher)
# 正向查询 - 通过Book查询Publisher
# 查询id为1的书籍的信息
book = Book.objects.get(id=1)
# 查询关联的publisher
publisher = book.publisher # 反向查询 - 通过Publisher查询Book
# Django会在 “一” 的实体中增加关联对象_set 属性,用于查询“多”的数据
# 结合 Publisher 和 Book 之间关系 :在 Publisher 中 增加了一个 book_set 属性
publisher=Publisher.objects.get(id=1)
books = publisher.book_set.all()

多对多关联

  多对多表示,A表中的一条记录能与B表中的多条记录相关联。反之,B表中的一条记录同样能与B表中的多条记录相关联。

  在数据库中的实现方式:

    必选创建第三张表,关联两张多对多的数据表

  1、在Django中实现方式:

    在任意一个要实现多对多关联的实体类中增加:

    属性(字段)名 = models.ManyToManyField(关联的实体类名)

  2、关联查询

# 实体类Author 与 Book多对多关联
class Author(models.Model):
... ...
book = models.ManyToManyField(Book)
# 正向查询-通过Author查询所有的Book
author = Author.objects.get(id=1)
# 通过 关联属性.all() 查询所有对应数据
books = author.book.all() # 反向查询-通过Book查询所有的Author
# Django中 会在Book(被关联) 实体中增加一个隐式属性author_set
book = Book.objects.get(id=1)
authors = book.author_set.all()

对于关联映射的总结:

  三种关联关系的查询中,都存在正向和反向两种查询方式

  正向查询都是直接用增加的关联属性进行查询就可以

  反向查询在Django中都会增加一个隐式属性,分别是:

    一对一:关联的实体类名(小写)

    一对多:在“一”的实体增加关联属性“_set”属性,用于查询"多"的数据

    多对多:与一对多类似。

未完待续......

python+Django框架运用(四)的更多相关文章

  1. [Python] Django框架入门

    说明:Django框架入门 当前项目环境:python3.5.django-1.11 项目名:test1 应用名:booktest 命令可简写为:python manager.py xxx => ...

  2. 利用 Python django 框架 输入汉字,数字,字符,等。。转成二维码!

    利用 Python django 框架 输入汉字,数字,字符,等..转成二维码! 模块必备:Python环境 + pillow  + qrcode 模块 核心代码import qrcode qr = ...

  3. Python Django框架笔记(三):django工作方式简单说明和创建用户界面

    (一)  说明 简单说明下django的工作方式,并举2个例子. (二)  Django工作方式 假定我们有下面这些文件 ,这里在前2篇的基础上增加了 templates目录(存放html文件) 和s ...

  4. Python Django框架笔记(一):安装及创建项目

     #推荐一本书<Python核心编程>(适合有一定基础的),美国人Wesley Chun编写的,京东.淘宝应该都有.我是觉得写的很好,详细.简洁.满满的干货,不像有的书整本看完也没什么用. ...

  5. python django框架(一)

    s4day63内容回顾: 1. 安装 2. 创建用户 + 授权 3. 连接 - 数据库 终端创建数据库(字符编码) - 数据表 终端 ORM pymysql create ...)engine=inn ...

  6. [Python] Django框架入门5——静态文件、中间件、上传图片和分页

    说明: 本文主要描述Django其他的内容,涉及静态文件处理.中间件.上传文件.分页等. 开发环境:win10.Python3.5.Django1.10. 一.静态文件处理 在Django项目的静态文 ...

  7. Python Django框架笔记(五):模型

    #前言部分来自Django Book (一)    前言 大多数web应用本质上: 1. 每个页面都是将数据库的数据以HTML格式进行展现. 2. 向用户提供修改数据库数据的方法.(例如:注册.发表评 ...

  8. python Django框架正式准备工作

    之前由于不太了解数据库方面的知识,但经过一段时间的web应用的开发学习,成功的用其他框架连接了数据库,并完成了相关操作,数据爬取也初识了,更了解了python这门语言的语法,但路还很长,因此现在才能正 ...

  9. Python——Django框架——django-simple-captcha(验证码)

    一.引用 包 pip install django-simple-captcha 二.将captcha加入setting的 INSTALLED_APPS 三.运行python manager.py m ...

  10. Python——Django框架——Model数据库模型

    一.设置 1.Django的setting中配置数据库(MySQL配置) DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql' ...

随机推荐

  1. 【CF739E】Gosha is hunting 贪心

    [CF739E]Gosha is hunting 题意:有n个小精灵,你有a个普通球和b个超级球,用普通球抓住第i只小精灵的概率为$A_i$,用超级球抓住第i只小精灵的概率为$u_i$.你必须一开始就 ...

  2. 安装pod

    1.ruby升级最新 sudo gem update -n /usr/local/bin --system 2. $ gem sources *** CURRENT SOURCES *** https ...

  3. 基础笔记1(进制,浮点,递归,floor,round和ceil)

    1,进制默认是十进制 0开头 8进制 0x     16进制 0b     2进制 2,long 的范围是19位数字.int范围是21亿左右,short 是三万二千左右. 超过int范围的long类型 ...

  4. Windows 8.1 100% 磁盘使用率解决方案

    前段时间我的win8电脑爆卡!动不动就卡死,一点都动不了. 好不容易打开了任务管理器,发现disk usage: 100%,实在是不理解,磁盘使用率100%怎么会影响流畅度?如果是CPU或内存还好理解 ...

  5. 上拉刷新和下拉刷新的两种方法(包括使用第三方库MJRefresh)

    一.使用苹果原生的方法 1.下拉刷新 2.上拉刷新 (1 首先要新建一个footer得XIB文件,当然同时包括对应的控制器文件,例如在XIB文件中可以如下拖拉对应的控件 (2 然后在代码文件中写一个实 ...

  6. Shell while

    while commanddo ...done c=0while [ $c -lt 5 ]do c='expr $c+1' echo $cdone

  7. HBase一次客户端读写异常解读分析与优化全过程(干货)

    大数据时代,HBase作为一款扩展性极佳的分布式存储系统,越来越多地受到各种业务的青睐,以求在大数据存储的前提下实现高效的随机读写操作.对于业务方来讲,一方面关注HBase本身服务的读写性能,另一方面 ...

  8. Linux磁盘处理

    查看磁盘占用率 df -l 既然确定了哪块磁盘占用率高,那就切换到这块磁盘检查一下这块磁盘的哪个文件夹占用高,再逐层去查找 du -h --max-depth=1

  9. CSU 1804 - 有向无环图 - [(类似于)树形DP]

    题目链接:http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1804 Bobo 有一个 n 个点,m 条边的有向无环图(即对于任意点 v,不存在从点 ...

  10. Alisha’s Party---hdu5437(模拟+优先队列)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5437 题意:公主有k个朋友来参加她的生日party,每个人都会带价值为v[i]的礼物过来,在所有人到齐 ...