感谢关注我的个人博客和教程官网liujiangblog.com
2019年4月1日,Django官方如期发布了2.2版本,这是一个LST版本,将持续维护和安全更新到2022年4月,也就是说至少有3年的生命周期,所以这是一个可以长期使用的版本。上一个LST版本Django1.11将在2020年4月停止维护。
在这里不得不吐糟一下Django的版本升级路线,版本号提升得太快了!!2.2之后就是3.0,并且3.0会在2019年12月份正式发布,这给一些初学者或者小公司带来太多的困惑,不知道该学或者该用哪个版本了。个人建议Python2.7没得选,只能使用Django1.11版本。Python3.x的,直接选最新版本或者最近的LST版本,差别不大。
2.2版本依然包含了一些新特新,和一些对前期版本不兼容的说明。
Django2.2支持Python3.5、3.6和3.7。
新的CheckConstraint和UniqueConstraint类现在开始支持自定义数据库约束,通过使用Meta.constraints选项。
小特性
1. django.contrib.admin
为TabularInline添加了列头的CSS类
2. django.contrib.auth
HttpRequest将被作为第一个位置参数传递给RemoteUserBackend.configure_user()方法。
3. django.contrib.gis
Envelope函数开始支持Oracle。
coveredby和covers查询现在支持SpatiaLite
不再支持GDAL1.9和1.10
4. django.contrib.staticfiles
为collectstatic --ignore
选项添加路由,以支持类似/vendor/*.js
的模式
5. Database backends
为SQLite上的QuerySet.iterator()
添加输出流
6. Generic Views
新的View.setup钩子将在调用dispatch()方法之前初始化视图属性。
7. Internationalization
现在支持亚美尼亚语言
8. Management Commands
- 新的选项
--force-color
强制对输出添加颜色 - inspectdb命令将为PostgreSQL数据库的外部表创建模型
-
inspectdb --include-views
将为Oracle和PostgreSQL的物化视图创建模型 -
inspectdb --include-partitions
将为PostgreSQL的分区表创建模型。 - 在Oracle和PostgreSQL上inspectdb命令将内省DurationField字段类型,在SQLite上内省AutoField字段类型。
- 在Oracle中,dbshell将被rlwrap包装起来。rlwrap提供一个命令历史记录和键盘输入编辑功能。
- 新的
makemigrations --no-header
选项可以在生成migration文件的时候避免写入头部注释。 - runserver命令现在可以使用
Watchman
插件,用于提高监视大量修改文件的性能。并且不再支持pyinotify插件。
9. Migrations
- 新的migrate --plan选项将打印出迁移操作的列表
- NoneType现在可以在migrations中序列化了
- 现在可以为migrations注册自定义的序列化器了
10. Models
- 为PostgreSQL ,新增Index.opclasses类
- 通过Index.condition,支持分区索引
- 新增NullIf和Reverse数据库函数
- 为
QuerySet.bulk_create()
函数新增ignore_conflicts
参数,此参数如果设置为True,将忽略在添加数据行时的错误。 - 新增ExtractIsoYear函数
- 新增
QuerySet.bulk_update()
方法,提高批量更新指定字段的效率 - 对于Model.save()、QuerySet.update()和Model.delete()等单独的操作,Django将不再启动一个事务,这有助于提高自动提交数据库操作的性能
- SQLite现在支持StdDev和Variance函数
- Aggregate类现在开始支持DISTINCT聚合操作
- RelatedManager.add()、create()、remove()、set()、
get_or_create()
、update_or_create()
等方法现在支持多对多关系。 - SQLite现在要求最低版本是3.8.3
- mysqlclient现在要求最低版本是1.3.13
11. Requests and Responses
新增HttpRequest.headers,可以快速地访问请求的头部信息
12. URLs
新增的ResolverMatch.route属性保存了匹配的URL模式的路由
13. Validators
MaxValueValidator、MinValueValidator、MinLengthValidator和MaxLengthValidator 现在可以接收一个可调用的limit_value参数值。
Django 2.2 版本中向后不兼容的地方
1. Admin actions的继承方式发生变化
原来是:
from django.contrib import admin
class BaseAdmin(admin.ModelAdmin):
actions = ['a']
class SubAdmin(BaseAdmin):
actions = ['b']
在过去,SubAdmin将同时具有'a'和'b'动作,这其实不符合Python继承语法的,因为actions属性被重写了。
现在,Django2.2将上面的做法改变成更符合Python继承机制,所以要达到上面目的的话,我们需要修改成下面的做法:
class SubAdmin(BaseAdmin):
actions = BaseAdmin.actions + ['b']
2. cached_property的继承机制发生改变
在过去,我们都是这么使用alias的:
from django.utils.functional import cached_property
class A:
@cached_property
def base(self):
return ...
alias = base
在Python3.6之后,这可能会导致TypeError,所以现在修改成下面的做法:
from django.utils.functional import cached_property
import operator
class A:
@cached_property
def base(self):
return ...
alias = property(operator.attrgetter('base'))
总结:2.2其实没啥新东西!
最后附上Django的版本路线图和生命周期图:
Django的版本号提高得太快我已经无力吐槽了。2.2之后就是3.0,这是几个意思?