This is a small manager that just adds a "bulk_insert" function. This is very basic, I'm basically throwing it up here because it's simple and works for my current needs. Feedback on improvements (which I know would be a ton) are very welcome.
Some known "gotchas":
- 
This doesn't handle relationships. If, however, you want to do one-to-one or foreignkeys you'll have to use the actual table column name ('whatever_id' typically) 
- 
When using this I typically make a bulk_insert call every 500 iterations or so 
Some improvements that I think could be good:
- 
Possibly just find the fields from the first object in the objs array and leave the fields argument as optional 
- 
Create a bulk_insert_from_file function and use LOAD DATA INFILE for mysql and whatever else supports it 
| 1 2 3 4 5 6 7 8 9 10 11 12 13 | from django.db import models
from django.db import connection
class BulkManager(models.Manager):
        def bulk_insert(self, fields, objs):
                qn = connection.ops.quote_name
                cursor = connection.cursor()
                flds = ', '.join([qn(f) for f in fields])
                values_list = [ r[f] for r in objs for f in fields]
                arg_string = ', '.join([u'(' + ', '.join(['%s']*len(fields)) + ')'] * len(objs))                   
                sql = "INSERT INTO %s (%s) VALUES %s" % (self.model._meta.db_table, flds, arg_string,)             
                cursor.execute(sql, values_list)
 | 
More like this
- Add Toggle Switch Widget to Django Forms by OgliariNatan 1 month, 2 weeks ago
- get_object_or_none by azwdevops 5 months, 1 week ago
- Mask sensitive data from logger by agusmakmun 7 months ago
- Template tag - list punctuation for a list of items by shapiromatron 1 year, 9 months ago
- JSONRequestMiddleware adds a .json() method to your HttpRequests by cdcarter 1 year, 9 months ago
Comments
what is the purpose of this thing?
#
Please login first before commenting.