Skip to content


Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

Fixed bulk_insertion on databases which don't yet support it. Thanks …

…to Justin Bronn for his Oracle wizardry.

git-svn-id: bcc190cf-cafb-0310-a4f2-bffc1f526a37
  • Loading branch information...
commit 807b2a8216cbb8bfc82a2dc3d57fe2169f3349e4 1 parent b45a4ac
@alex alex authored
Showing with 3 additions and 2 deletions.
  1. +3 −2 django/db/models/sql/
5 django/db/models/sql/
@@ -814,7 +814,8 @@ def as_sql(self):
values = [[self.connection.ops.pk_default_value()] for obj in self.query.objs]
params = [[]]
fields = [None]
- can_bulk = not any(hasattr(field, "get_placeholder") for field in fields) and not self.return_id
+ can_bulk = (not any(hasattr(field, "get_placeholder") for field in fields) and
+ not self.return_id and self.connection.features.has_bulk_insert)
if can_bulk:
placeholders = [["%s"] * len(fields)]
@@ -831,7 +832,7 @@ def as_sql(self):
result.append(r_fmt % col)
params += r_params
return [(" ".join(result), tuple(params))]
- if can_bulk and self.connection.features.has_bulk_insert:
+ if can_bulk:
result.append(self.connection.ops.bulk_insert_sql(fields, len(values)))
return [(" ".join(result), tuple([v for val in values for v in val]))]
Please sign in to comment.
Something went wrong with that request. Please try again.