From a6a402a7db45ea7d2bb8521b989de573c4f72fee Mon Sep 17 00:00:00 2001 From: Malcolm Tredinnick Date: Thu, 10 Aug 2006 03:55:03 +0000 Subject: [PATCH] Fixed #2512 -- Fixed SQL error when saving existing empty models. git-svn-id: http://code.djangoproject.com/svn/django/trunk@3548 bcc190cf-cafb-0310-a4f2-bffc1f526a37 --- django/db/models/base.py | 11 ++++++----- tests/modeltests/empty/models.py | 2 ++ 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/django/db/models/base.py b/django/db/models/base.py index 657236571d..bdae7eccc2 100644 --- a/django/db/models/base.py +++ b/django/db/models/base.py @@ -176,11 +176,12 @@ class Model(object): # If it does already exist, do an UPDATE. if cursor.fetchone(): db_values = [f.get_db_prep_save(f.pre_save(self, False)) for f in non_pks] - cursor.execute("UPDATE %s SET %s WHERE %s=%%s" % \ - (backend.quote_name(self._meta.db_table), - ','.join(['%s=%%s' % backend.quote_name(f.column) for f in non_pks]), - backend.quote_name(self._meta.pk.column)), - db_values + [pk_val]) + if db_values: + cursor.execute("UPDATE %s SET %s WHERE %s=%%s" % \ + (backend.quote_name(self._meta.db_table), + ','.join(['%s=%%s' % backend.quote_name(f.column) for f in non_pks]), + backend.quote_name(self._meta.pk.column)), + db_values + [pk_val]) else: record_exists = False if not pk_set or not record_exists: diff --git a/tests/modeltests/empty/models.py b/tests/modeltests/empty/models.py index c50878398d..0f5a0b870f 100644 --- a/tests/modeltests/empty/models.py +++ b/tests/modeltests/empty/models.py @@ -20,5 +20,7 @@ API_TESTS = """ 2 >>> m.id is not None True +>>> existing = Empty(m.id) +>>> existing.save() """