#24424: Removing a model's last field results in SQL syntax error on SQLite
----------------------------+------------------------------------
Reporter: adnam | Owner: adnam
Type: Bug | Status: assigned
Component: Migrations | Version: 1.7
Severity: Normal | Resolution:
Keywords: | Triage Stage: Accepted
Has patch: 1 | Needs documentation: 1
Needs tests: 1 | Patch needs improvement: 1
Easy pickings: 0 | UI/UX: 0
----------------------------+------------------------------------
Comment (by MarkusH):
Initial models and migration:
{{{#!python
# models.py
from django.db import models
class Thing(models.Model):
pass
class Blob(Thing):
pass
# 0001_initial.py
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
]
operations = [
migrations.CreateModel(
name='Thing',
fields=[
('id', models.AutoField(auto_created=True,
primary_key=True, serialize=False, verbose_name='ID')),
],
),
migrations.CreateModel(
name='Blob',
fields=[
('thing_ptr', models.OneToOneField(auto_created=True,
parent_link=True, primary_key=True, serialize=False, to='app_a.Thing')),
],
bases=('app_a.thing',),
),
]
}}}
Making `Thing` inherit a new model `Bar`:
{{{#!python
# models.py
from django.db import models
class Bar(models.Model):
pass
class Thing(Bar):
pass
class Blob(Thing):
pass
# 0002_auto.py
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('app_a', '0001_initial'),
]
operations = [
migrations.CreateModel(
name='Bar',
fields=[
('id', models.AutoField(auto_created=True,
primary_key=True, serialize=False, verbose_name='ID')),
],
),
migrations.RemoveField(
model_name='thing',
name='id',
),
migrations.AddField(
model_name='thing',
name='bar_ptr',
field=models.OneToOneField(auto_created=True, default=0,
parent_link=True, primary_key=True, serialize=False, to='app_a.Bar'),
preserve_default=False,
),
]
}}}
{{{
Operations to perform:
Target specific migration: 0002_auto_20150307_1707, from app_a
Running migrations:
Rendering model states... DONE
Applying app_a.0002_auto_20150307_1707...
('CREATE TABLE `app_a_bar` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY
KEY)', None)
('SELECT engine FROM information_schema.tables WHERE table_name = %s',
['app_a_bar'])
('ALTER TABLE `app_a_thing` DROP COLUMN `id` CASCADE', [])
Traceback (most recent call last):
File "/home/markus/Coding/django/django/db/backends/utils.py", line 64,
in execute
return self.cursor.execute(sql, params)
File "/home/markus/Coding/django/django/db/backends/mysql/base.py", line
125, in execute
return self.cursor.execute(query, args)
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/cursors.py", line 219, in execute
self.errorhandler(self, exc, value)
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/connections.py", line 38, in defaulterrorhandler
raise errorvalue
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/cursors.py", line 205, in execute
r = self._query(query)
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/cursors.py", line 372, in _query
rowcount = self._do_query(q)
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/cursors.py", line 336, in _do_query
db.query(q)
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/connections.py", line 282, in query
_mysql.connection.query(self, query)
_mysql_exceptions.OperationalError: (1090, "You can't delete all columns
with ALTER TABLE; use DROP TABLE instead")
The above exception was the direct cause of the following exception:
Traceback (most recent call last):
File "manage.py", line 10, in <module>
execute_from_command_line(sys.argv)
File "/home/markus/Coding/django/django/core/management/__init__.py",
line 330, in execute_from_command_line
utility.execute()
File "/home/markus/Coding/django/django/core/management/__init__.py",
line 322, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "/home/markus/Coding/django/django/core/management/base.py", line
347, in run_from_argv
self.execute(*args, **cmd_options)
File "/home/markus/Coding/django/django/core/management/base.py", line
398, in execute
output = self.handle(*args, **options)
File
"/home/markus/Coding/django/django/core/management/commands/migrate.py",
line 195, in handle
executor.migrate(targets, plan, fake=fake, fake_initial=fake_initial)
File "/home/markus/Coding/django/django/db/migrations/executor.py", line
94, in migrate
self.apply_migration(states[migration], migration, fake=fake,
fake_initial=fake_initial)
File "/home/markus/Coding/django/django/db/migrations/executor.py", line
131, in apply_migration
state = migration.apply(state, schema_editor)
File "/home/markus/Coding/django/django/db/migrations/migration.py",
line 111, in apply
operation.database_forwards(self.app_label, schema_editor, old_state,
project_state)
File
"/home/markus/Coding/django/django/db/migrations/operations/fields.py",
line 121, in database_forwards
schema_editor.remove_field(from_model,
from_model._meta.get_field(self.name))
File "/home/markus/Coding/django/django/db/backends/base/schema.py",
line 441, in remove_field
self.execute(sql)
File "/home/markus/Coding/django/django/db/backends/base/schema.py",
line 107, in execute
cursor.execute(sql, params)
File "/home/markus/Coding/django/django/db/backends/utils.py", line 79,
in execute
return super(CursorDebugWrapper, self).execute(sql, params)
File "/home/markus/Coding/django/django/db/backends/utils.py", line 64,
in execute
return self.cursor.execute(sql, params)
File "/home/markus/Coding/django/django/db/utils.py", line 95, in
__exit__
six.reraise(dj_exc_type, dj_exc_value, traceback)
File "/home/markus/Coding/django/django/utils/six.py", line 658, in
reraise
raise value.with_traceback(tb)
File "/home/markus/Coding/django/django/db/backends/utils.py", line 64,
in execute
return self.cursor.execute(sql, params)
File "/home/markus/Coding/django/django/db/backends/mysql/base.py", line
125, in execute
return self.cursor.execute(query, args)
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/cursors.py", line 219, in execute
self.errorhandler(self, exc, value)
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/connections.py", line 38, in defaulterrorhandler
raise errorvalue
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/cursors.py", line 205, in execute
r = self._query(query)
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/cursors.py", line 372, in _query
rowcount = self._do_query(q)
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/cursors.py", line 336, in _do_query
db.query(q)
File "/home/markus/.venvs/django-dev-py3/lib/python3.4/site-
packages/MySQLdb/connections.py", line 282, in query
_mysql.connection.query(self, query)
django.db.utils.OperationalError: (1090, "You can't delete all columns
with ALTER TABLE; use DROP TABLE instead")
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/24424#comment:12>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.
--
You received this message because you are subscribed to the Google Groups
"Django updates" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
To post to this group, send email to [email protected].
To view this discussion on the web visit
https://groups.google.com/d/msgid/django-updates/063.0ceb3814b5e84747ab785acdb44f856b%40djangoproject.com.
For more options, visit https://groups.google.com/d/optout.