gzjjgod

I am new also, but I noticed right away that you had quotes around Speaker

speakers = models.ManyToManyField("Speaker")
That may be the problem.  I have added manytomany fields after the fact and
had no problems.

Good luck!
On Thu, Apr 2, 2009 at 10:02 AM, jjgod <gzjj...@gmail.com> wrote:

>
> Hi,
>
> I'm running Django version 1.1 beta 1 SVN-10368.
>
> I'm having a problem trying to a ManyToMany field to an existing
> model.
>
> In an application called "videos", I created a models.py like this:
>
> from django.db import models
>
> class Speaker(models.Model):
>    name = models.CharField(max_length=200)
>    localized_name = models.CharField(max_length=200)
>    bio = models.TextField()
>
> class Video(models.Model):
>    title = models.CharField(max_length=200)
>    localized_title = models.CharField(max_length=200)
>    description = models.TextField()
>    filmed_on = models.DateField('date filmed')
>    video_url = models.URLField(verify_exists=False)
>    subtitle_url = models.URLField(verify_exists=False)
>
> then I add
>
>    speakers = models.ManyToManyField("Speaker")
>
> to the end of Video class.
>
> when I run "python manage.py sql videos", it returns:
>
> BEGIN;
> CREATE TABLE "videos_speaker" (
>    "id" integer NOT NULL PRIMARY KEY,
>    "name" varchar(200) NOT NULL,
>    "localized_name" varchar(200) NOT NULL,
>    "bio" text NOT NULL
> )
> ;
> CREATE TABLE "videos_video" (
>    "id" integer NOT NULL PRIMARY KEY,
>    "title" varchar(200) NOT NULL,
>    "localized_title" varchar(200) NOT NULL,
>    "description" text NOT NULL,
>    "filmed_on" date NOT NULL,
>    "video_url" varchar(200) NOT NULL,
>    "subtitle_url" varchar(200) NOT NULL
> )
> ;
> CREATE TABLE "videos_video_speakers" (
>    "id" integer NOT NULL PRIMARY KEY,
>    "video_id" integer NOT NULL REFERENCES "videos_video" ("id"),
>    "speaker_id" integer NOT NULL REFERENCES "videos_speaker" ("id"),
>    UNIQUE ("video_id", "speaker_id")
> )
> ;
> COMMIT;
>
> which seems to be fine for me. Then I run "python manage.py syncdb",
> yet it does not create any new table for me, and when I try to look
> into the database generated with sqlite3 <dbname>, it shows:
>
> sqlite> .tables
> auth_group                  django_admin_log
> auth_group_permissions      django_content_type
> auth_message                django_session
> auth_permission             django_site
> auth_user                   videos_speaker
> auth_user_groups            videos_video
> auth_user_user_permissions
>
> which apparently does not have the last table described in "python
> manage.py sql videos". Then I try to add a video object in admin page,
> it gives me error page like this:
>
> OperationalError at /admin/videos/video/1/
> no such table: videos_video_speakers
>
> I'm fairly new to Django, so I really wish to know if I missed
> something. Thanks in advance.
> >
>


-- 
Joey Gartin

--~--~---------~--~----~------------~-------~--~----~
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
-~----------~----~----~----~------~----~------~--~---

Reply via email to