一.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的更多相关文章

  1. 76、django之内置Admin

    本篇导航: 配置路由 定制Admin Django内置的Admin是对于model中对应的数据表进行增删改查提供的组件,使用方式有: 依赖APP: django.contrib.auth django ...

  2. django之内置Admin

    本篇导航: 配置路由 定制Admin Django内置的Admin是对于model中对应的数据表进行增删改查提供的组件,使用方式有: 依赖APP: django.contrib.auth django ...

  3. Django学习:创建admin后台管理站点

    Django自带一个后台管理站点,方便我们管理数据.这个界面只给管理员使用,并不对大众开放. 创建管理员用户 py manage.py createsuperuser 如下图所示: 用户名不填的话,默 ...

  4. perl学习之内置变量

    Perl内置特殊变量   一.正则表达式特殊变量:1.$n  :包含上次模式匹配的第n个子串2.$& :前一次成功模式匹配的字符串3.$`  :前次匹配成功的子串之前的内容4.$’ :前次匹配 ...

  5. python学习之内置函数(二)

    4.7.3 内置函数(2) int() str() bool() set() list():将一个可迭代对象转化为列表 tuple():将一个可迭代对象转换成元组 dic(): 通过相应的方式创建字典 ...

  6. python学习之内置函数(一)

    4.7 内置函数 4.7.1 内置函数(1) eval 执行字符串类型的代码,并返回最终结果. eval('2 + 2') # 4 n=81 eval("n + 4") # 85 ...

  7. Django学习笔记(9)—— 开发用户注册与登录系统

    一,项目题目: 开发用户注册与登录系统 该项目主要练习使用Django开发一个用户注册与登录的系统,通过这个项目然后巩固自己这段时间所学习的Django知识. 二,项目需求: 开发一个简单的用户登录与 ...

  8. Django学习笔记(13)——Django的用户认证(Auth)组件,视图层和QuerySet API

    用户认证组件的学习 用户认证是通过取表单数据根数据库对应表存储的值做比对,比对成功就返回一个页面,不成功就重定向到登录页面.我们自己写的话当然也是可以的,只不过多写了几个视图,冗余代码多,当然我们也可 ...

  9. Django学习笔记(16)——扩展Django自带User模型,实现用户注册与登录

    一,项目题目:扩展Django自带User模型,实现用户注册与登录 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册,登录,用户认证,注销,修改密码等功能. ...

随机推荐

  1. 再见2018,你好2019 -- 致 Mac 背后的自己

    转眼间 2018 年即将过去,心有万千感慨,真的感觉到时间如白驹过隙,成长没有跟上时间的脚步,这叫老了一岁,如果跟上了,那就叫成熟了一岁.很遗憾,2018年我老了一岁. 新年之初,立过好几个 Flag ...

  2. 使用js制作 下拉选择日期列表 (即日期选择器)

    上代码 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <tit ...

  3. .NET中的字符串(1):字符串 - 特殊的引用类型

    C# string 特殊的引用类型 .Net 框架程序设计(修订版)中有这样一段描述:String类型直接继承自Object,这使得它成为一个引用类型,也就是说线程上的堆栈上不会驻留有任何字符串.(译 ...

  4. 增加phpmyadmin导入文件上限

    一.修改php配置 修改php配置文件,php.ini upload_max_filesize = 100M post_max_size = 100M 一般修改这2个就行了,然后重启wampserve ...

  5. 吴裕雄--天生自然Numpy库学习笔记:NumPy 统计函数

    NumPy 提供了很多统计函数,用于从数组中查找最小元素,最大元素,百分位标准差和方差等. numpy.amin() 用于计算数组中的元素沿指定轴的最小值. numpy.amax() 用于计算数组中的 ...

  6. docker+hexo 搭建博客

    前提 Linux服务器 保证自己服务器上的端口对外开放,即设置相应的防火墙规则 安装好hexo 安装:npm install hexo-cli -g 初始化搭建:npm init myBlog,myB ...

  7. 疫情对国内5G发展的影响

    导读 2020年春节期间,“新型冠状病毒”引发了自SARS之后又一次全国性疫情,而世卫组织也将之列为国际关注的突发公共卫生事件,随后多国发布了针对中国的旅行警告和入境限制,从当前情况来看,疫情对中国各 ...

  8. 【PAT甲级】1046 Shortest Distance (20 分)

    题意: 输入一个正整数N(<=1e5),代表出口的数量,接下来输入N个正整数表示当前出口到下一个出口的距离.接着输入一个正整数M(<=10000),代表询问的次数,每次询问输入两个出口的序 ...

  9. iOS 开发之 RunLoop 详解

    1)什么是 Runloop ? 1.字面上是运行循环,内部就是 do-while 循环,在这个循环内不断地处理各种任务. 2.一个线程对应一个 Runloop ,主线程的 RunLoop 默认是开启的 ...

  10. 「Luogu P1975 [国家集训队]排队」

    题目大意 给出一个序列 \(h\),支持交换其中的两数,求出每一时刻的逆序对个数. 分析 求逆序对是 \(O(N\log_2N)\) 的,有 \(M\) 个操作,如果暴力求的话时间复杂度就是 \(O( ...