This is by design. syncdb only checks to see if it needs to create any new DB tables for any models; it does NOT alter existing model tables. See http://docs.djangoproject.com/en/dev/ref/django-admin/#syncdb for more info.
If you don't have any valuable data in the table (ie, you're just developing or playing around), the best thing to do is drop the whole table from the DB entirely, and then syncdb will recreate it from scratch with the new column included. You can also just issue an ALTER TABLE to add the column manually with the proper name, and Django will recognize it. Good luck, Aneesh On Apr 16, 9:00 am, gry <georgeryo...@gmail.com> wrote: > [django: 1.1 beta 1 SVN-10407, python 2.5.2, ubuntu] > My first django toy app. I've been working through the > tutorialhttp://docs.djangoproject.com/en/dev/intro/tutorial02/. > I've already done a few cycles of (change-model, ./manage.py syncdb) > with success. > I just added email and birthday fields to my Person model: > > class Person(models.Model): > name = models.CharField(max_length=200) > def formalname(self): > return 'Mr(Ms) ' + self.name > phone = models.CharField(max_length=13) > address = models.ForeignKey(Address) > email = models.EmailField() > birthday = models.DateField() > def __unicode__(self): > return self.name > > I killed the server process(maybe not necessary). I did ./manage.py > syncdb . > Now "./manage.py sql phones" reports: > CREATE TABLE "phones_person" ( > "id" integer NOT NULL PRIMARY KEY, > "name" varchar(200) NOT NULL, > "phone" varchar(13) NOT NULL, > "address_id" integer NOT NULL REFERENCES "phones_address" ("id"), > "email" varchar(75) NOT NULL, > "birthday" date NOT NULL > ) > but dbshell shows: > CREATE TABLE "phones_person" ( > "id" integer NOT NULL PRIMARY KEY, > "name" varchar(200) NOT NULL, > "phone" varchar(13) NOT NULL, > "address_id" integer NOT NULL REFERENCES "phones_address" ("id") > ); > > I restart the server andhttp://127.0.0.1:8000/admin/phones/person/ > gets me "Exception Value: > no such column: phones_person.email". > > Why is my change not making it into the DB? I even did "./manage.py > flush" and it still fails on the email field. > > -- George --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Django users" group. To post to this group, send email to django-users@googlegroups.com To unsubscribe from this group, send email to django-users+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/django-users?hl=en -~----------~----~----~----~------~----~------~--~---