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版本依然包含了一些新特新,和一些对前期版本不兼容的说明。
Python兼容性
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.3mysqlclient现在要求最低版本是1.3.13
11. Requests and Responses
新增HttpRequest.headers,可以快速地访问请求的头部信息
12. URLs
新增的ResolverMatch.route属性保存了匹配的URL模式的路由
13. Validators
MaxValueValidator、MinValueValidator、MinLengthValidator和MaxLengthValidator 现在可以接收一个可调用的limit_value参数值。
2.2版本中向后不兼容的地方
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']
cached_property语法发生改变
在过去,我们都是这么使用alias的:
from django.utils.functional import cached_propertyclass A: @cached_property def base(self): return ... alias = base
在Python3.6之后,这可能会导致TypeError,所以现在修改成下面的做法:
from django.utils.functional import cached_propertyimport operatorclass A: @cached_property def base(self): return ... alias = property(operator.attrgetter('base'))
总结:2.2其实没啥新东西!
最后附上Django的版本路线图和生命周期图:
Django的版本号提高得太快我已经无力吐槽了。2.2之后就是3.0,这是几个意思?