Django 学习之内置Admin
一.Admin组件
Django内置的Admin是对于model中对应的数据表进行增删改查提供的组件,使用方式有:
Django Admin内部依赖:
依赖APP:
django.contrib.auth
django.contrib.contenttypes
django.contrib.messages
django.contrib.sessions
模板的context_processors:
django.contrib.auth.context_processors.auth
django.contrib.messages.context_processors.messages
中间件:
django.contrib.auth.middleware.AuthenticationMiddleware
django.contrib.messages.middleware.MessageMiddleware
1.配置路由
通常我们在生成项目时会在 urls.py 中自动设置好。
from django.contrib import adminfrom django.urls import path
urlpatterns = [
path('admin/', admin.site.urls),
]
当前配置的路由可以创建一些路由映射关系:
/admin/
/admin/login/
/admin/logout/
/admin/password_change/
/admin/password_change/done/
/admin/app名称/model名称/
/admin/app名称/model名称/add/
/admin/app名称/model名称/ID值/history/
/admin/app名称/model名称/ID值/change/
/admin/app名称/model名称/ID值/delete/
2.使用admin工具
在使用admin组件之前,需要将app下的模型类,进行注册。
app下 models.py 文件:
from django.db import models class Book(models.Model):
title = models.CharField(max_length=32)
price = models.DecimalField(max_digits=5, decimal_places=2)
pub_date = models.DateField()
publish = models.ForeignKey("Publish", on_delete=models.CASCADE)
authors = models.ManyToManyField("Author") def __str__(self):
return self.title class Publish(models.Model):
name = models.CharField(max_length=32)
city = models.CharField(max_length=64)
email = models.EmailField() def __str__(self):
return self.name class Author(models.Model):
name = models.CharField(max_length=32)
age = models.SmallIntegerField()
au_detail = models.OneToOneField("AuthorDetail", on_delete=models.CASCADE) def __str__(self):
return self.name class AuthorDetail(models.Model):
gender_choices = (
(0, "女"),
(1, "男"),
(2, "保密"),
)
gender = models.SmallIntegerField(choices=gender_choices)
tel = models.CharField(max_length=32)
addr = models.CharField(max_length=64)
birthday = models.DateField()
models.py
启动服务器,然后在浏览器中访问 http://127.0.0.1:8000/admin/,得到登录界面。

你可以通过命令 python manage.py createsuperuser 来创建超级用户。然后,来进行登录操作。
为了让 admin 界面管理某个数据模型,我们需要先注册该数据模型到 admin。
在admin.py中只需要将Mode中的某个类注册,即可在Admin中实现增删改查的功能,如:
admin.site.register(models.Book, )
admin.site.register(models.Publish, )
admin.site.register(models.Author, )
admin.site.register(models.AuthorDetail, )
登录后显示:

这时候就已经可以进行数据的添加了。
但是,这种方式比较简单,如果想要进行更多的定制操作,需要利用ModelAdmin进行操作。
3.admin的定制
我们可以自定制类继承 admin.ModelAdmin 类,来扩展方法。有以下两种方式注册:
看下面的注册方法请注意,类的命名是固定的:models中的类名+Admin ,请注意下面的格式。
# 方式一:(注册book表)
class BookAdmin(admin.ModelAdmin):
list_display = ('title', 'price', 'publish', 'pub_date')
admin.site.register(models.Book, BookAdmin)
# 方式二:(注册publish表,并显示字段)
@admin.register(models.Publish)
class PublishAdmin(admin.ModelAdmin):
list_display = ('name', 'city', 'email')
方式一效果图:

可以显示这些列
方式二效果图:

ModelAdmin中提供了大量的可定制功能,下面我们列举一下常用的功能:
class BookAdmin(admin.ModelAdmin):
list_display = ('title', 'price', 'publish', 'pub_date', 'show_author') # 定制展示的列
list_display_links = ('price',) # 定制跳转的列
list_filter = ('publish', 'authors') # 定制过滤列
search_fields = ('title', 'price') # 定制模糊搜索列
list_editable = ('title',) # 定制可以直接编辑的列
actions = ['patch_init'] # 定制批量处理方法
ordering = ['-price'] # 通过该列进行排序,默认升序
def show_author(self, obj): # 自定制展示列
return "|".join([i.name for i in obj.authors.all()])
def patch_init(self, request, queryset): # 初始化单价
queryset.update(price=100)
patch_init.short_description = "批量初始化" # 设置操作名称
admin.site.register(models.Book, BookAdmin)
定制跳转的列
点击设置的跳转列,进入后效果(可以修改信息)

定制模糊搜索列(不能将关联的字段加到模糊搜索中)
可以通过模糊搜索,价格或出版社名:

定制可以直接编辑的列
可以直接进行修改(一般不这样用)

定制批量处理方法


通过该列进行排序,默认升序


4.1271, Illegal mix of collations for operation 'like'解决方法
在admin模糊查询中加到一定的字段,在查询中文时,出现报错:
(1271, "Illegal mix of collations for operation 'like'")

问题所在是:
MySQL Illegal mix of collations for operation 'like'
在 MySQL 5.5 以上, 若字段类型 Type 是 time,date,datetime
select时如果使用 like '%中文%' 会出现 Illegal mix of collations for operation 'like'
执行时可能就会出现时间字段 like '%中文%' 这种语法,旧版的 MySQL 是不会出现错误的.
升到 MySQL 5.5 以上, 必需改成 like binary '%中文%' 即可避免出现错误.
解决方法:
进入:
C:\python\py\Lib\site-packages\django\db\backends\mysql\base.py
根据情况查看自己相应的文件
C:\python\py 为我的python环境安装目录
找到对应的db路径下的base.py文件

'icontains': 'LIKE %s', 改为: 'icontains': 'LIKE BINARY %s',
重启后模糊查询中文可以了:

Django 学习之内置Admin的更多相关文章
- 76、django之内置Admin
		本篇导航: 配置路由 定制Admin Django内置的Admin是对于model中对应的数据表进行增删改查提供的组件,使用方式有: 依赖APP: django.contrib.auth django ... 
- django之内置Admin
		本篇导航: 配置路由 定制Admin Django内置的Admin是对于model中对应的数据表进行增删改查提供的组件,使用方式有: 依赖APP: django.contrib.auth django ... 
- Django学习:创建admin后台管理站点
		Django自带一个后台管理站点,方便我们管理数据.这个界面只给管理员使用,并不对大众开放. 创建管理员用户 py manage.py createsuperuser 如下图所示: 用户名不填的话,默 ... 
- perl学习之内置变量
		Perl内置特殊变量 一.正则表达式特殊变量:1.$n :包含上次模式匹配的第n个子串2.$& :前一次成功模式匹配的字符串3.$` :前次匹配成功的子串之前的内容4.$’ :前次匹配 ... 
- python学习之内置函数(二)
		4.7.3 内置函数(2) int() str() bool() set() list():将一个可迭代对象转化为列表 tuple():将一个可迭代对象转换成元组 dic(): 通过相应的方式创建字典 ... 
- python学习之内置函数(一)
		4.7 内置函数 4.7.1 内置函数(1) eval 执行字符串类型的代码,并返回最终结果. eval('2 + 2') # 4 n=81 eval("n + 4") # 85 ... 
- Django学习笔记(9)—— 开发用户注册与登录系统
		一,项目题目: 开发用户注册与登录系统 该项目主要练习使用Django开发一个用户注册与登录的系统,通过这个项目然后巩固自己这段时间所学习的Django知识. 二,项目需求: 开发一个简单的用户登录与 ... 
- Django学习笔记(13)——Django的用户认证(Auth)组件,视图层和QuerySet API
		用户认证组件的学习 用户认证是通过取表单数据根数据库对应表存储的值做比对,比对成功就返回一个页面,不成功就重定向到登录页面.我们自己写的话当然也是可以的,只不过多写了几个视图,冗余代码多,当然我们也可 ... 
- Django学习笔记(16)——扩展Django自带User模型,实现用户注册与登录
		一,项目题目:扩展Django自带User模型,实现用户注册与登录 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册,登录,用户认证,注销,修改密码等功能. ... 
随机推荐
- mybatis批量插入和更新
			批量插入 <insert id="add" parameterType="java.util.List"> insert all <forea ... 
- sqli-libs(5-10关)
			Less_5 补充基础知识 1. left(a,b)左侧截取a的前b位,正确则返回1,错误则返回o Select left(database(),1)=’s’; 其中database()为sec ... 
- java篇 之  集合
			集合 链接:https://blog.csdn.net/weixin_42504145/article/details/83119088 数组: java的数组既可以存储基本数据类型,也可以存储引 ... 
- ACM进阶之路
			第一阶段:练经典常用算法,下面的每个算法给我打上十到二十遍,同时自己精简代码, 因为太常用,所以要练到写时不用想,10-15分钟内打完,甚至关掉显示器都可以把程序打 出来. 3.大数(高精度)加减乘除 ... 
- TensorFlow使用RNN实现手写数字识别
			学习,笔记,有时间会加注释以及函数之间的逻辑关系. # https://www.cnblogs.com/felixwang2/p/9190664.html # https://www.cnblogs. ... 
- php引入html页面 css报错 404
			php引入html页面 css报错 404, html页面内 有css, 有一样 是这么写的 结果就报错了, 原来是 -moz这一句,在这句前面随便加一句别的样式就可以.... 
- JS中的提升(即变量和函数声明移动到代码顶部)
			先看代码(第一个代码片段): console.log(a); var a = 1; 如果你认为这是一段不合法的代码,在调用console.log()的时候会输出undefined,你完全正确.但是如果 ... 
- [Thiinking in Java]自闭学习之路(一)构造器
			前言- 本文是为个人学习做的整理性质的笔记,肯定带有许多不妥的地方,仅供参考. (第五章·初始化与清理 <Thinking in Java>) 用构造器确保初始化 正文- 构造器: 什么是 ... 
- HDU4280 Island Transport
			ISAP求最大流模板 #include<cstdio> #include<cstring> #include<algorithm> #include<iost ... 
- ZOJ1004 Anagrams by Stack
			题目大意:规定 i 为入栈,o 为出栈,现在给两个字符串st1,st2,现在要将st1转化为st2,转化方法是,st1中字符从头开始入栈,并合理出栈构造出st2.请输出所有可能的出入栈步骤. 深度优先 ... 
