paw*_*.ad 5 django django-reversion django-1.8
我想在django-reversion中保存新的对象版本.我浏览了文档,但没有找到任何相关信息.我怎样才能实现它?
您可以使用该ignore_duplicates选项。很遗憾
如果您确实想忽略跟随关系的重复项,则有两种可能性:
删除and explicit此处https://github.com/etianen/django-reversion/blob/master/reversion/revisions.py#L199
设置ignore_duplicates为True默认https://github.com/etianen/django-reversion/blob/master/reversion/revisions.py#L368
请小心,如上所述,它可能会很慢。
设置ignore_duplicates为False并添加信号接收器:
from django.db import transaction
from django.dispatch import receiver
from reversion.models import Revision, Version
from reversion.signals import post_revision_commit
def clear_versions(versions, revision):
count = 0
for version in versions:
previous_version = Version.objects.filter(
object_id=version.object_id,
content_type_id=version.content_type_id,
db=version.db,
id__lt=version.id,
).first()
if not previous_version:
continue
if previous_version._local_field_dict == version._local_field_dict:
version.delete()
count += 1
if len(versions_ids) == count:
revision.delete()
@receiver(post_revision_commit)
def post_revision_commit_receiver(sender, revision, versions, **kwargs):
transaction.on_commit(lambda: clear_versions(versions, revision))
Run Code Online (Sandbox Code Playgroud)
它也可能很慢,但您可以异步执行(例如,在 Celery 任务中):
# tasks.py
@celery.task(time_limit=60, ignore_result=True)
def clear_versions(revision_id, versions_ids):
count = 0
if versions_ids:
for version in Version.objects.filter(id__in=versions_ids):
previous_version = Version.objects.filter(
object_id=version.object_id,
content_type_id=version.content_type_id,
db=version.db,
id__lt=version.id,
).first()
if not previous_version:
continue
if previous_version._local_field_dict == version._local_field_dict:
version.delete()
count += 1
if len(versions_ids) == count:
Revision.objects.only('id').get(id=revision_id).delete()
# signals.py
@receiver(post_revision_commit)
def post_revision_commit_receiver(sender, revision, versions, **kwargs):
transaction.on_commit(
lambda: clear_versions.delay(revision.id, [v.id for v in versions])
)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
376 次 |
| 最近记录: |