Opened 6 weeks ago

Closed 6 weeks ago

#35975 closed Uncategorized (duplicate)

New feature: faster fixture loading via loaddata command

Reported by: JorisBenschop Owned by: JorisBenschop
Component: Core (Management commands) Version: 5.1
Severity: Normal Keywords: loaddata
Cc: Triage Stage: Unreviewed
Has patch: yes Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description

As per this forum discussion, I have created a patch to improve load times for the loaddata command under some circumstances.

Currently the “loaddata” management command uses the obj.save() method for each deserialized object within a fixture. This function first tries an UPDATE statement and, if that fails, tries an INSERT statement.

I propose to add two optional flags to the loaddata command:

–force-insert adds the “force_insert=True” to the save() method. This reduces load time by ~50% but has an increased risk of the upload failing in case the record already exists.

–bulk_create: This option groups records in the fixture by the model, and insert the group as a single bulk_create statement. For large fixtures, I have achieved a 1000-fold improvement in loading time. It has a number of risks (already described in the bulk_create section), notably that it skips some routines covered in the save() method of the model.

Both these flags are supposed to be run by people who know that above-mentioned issues will not be a problem for them, and should not be enabled by default.

Change History (3)

comment:1 by JaeHyuckSa, 6 weeks ago

Owner: set to JorisBenschop
Status: newassigned

comment:2 by JorisBenschop, 6 weeks ago

Component: UncategorizedCore (Management commands)

comment:3 by Sarah Boyce, 6 weeks ago

Resolution: duplicate
Status: assignedclosed

Duplicate of #35904

Note: See TracTickets for help on using tickets.
Back to Top