Thanks for the reply. I did not syncdb with any blank=True or
null=True options on the foreignkeys, so the MySQL table does not
allow null values. I just ran some group and counts from the mysql
shell and it does indeed show that a number of records have a zero in
their fk_id field. So I'm now leaning toward that being the problem,
since it seems to match what the traceback is pointing to as a
problem.

So what's the right cleanup? Alter the column so it allows nulls,
update the zeros to nulls and then flip some null=True options into my
models.py?

On Oct 22, 3:29 pm, "Karen Tracey" <[EMAIL PROTECTED]> wrote:
> On Wed, Oct 22, 2008 at 6:14 PM, perchance <[EMAIL PROTECTED]> wrote:
>
> > [trimmed]
> > python manage.py dumpdata app_label --traceback --indent 4 > fixtures/
> > app_label.js
>
> > And the traceback I get looks like this, with a sanitized model name
> > substituted for the real thing.
>
> > """
> > Traceback (most recent call last):
> > [snipped]
> >  File "/Library/Frameworks/Python.framework/Versions/2.4/lib/
> > python2.4/site-packages/django/db/models/query.py", line 308, in get
> >    raise self.model.DoesNotExist("%s matching query does not exist."
> > django.db.models.base.DoesNotExist: Model matching query does not
> > exist.
> > ""
>
> > The models.py is pretty simple. There are three models up top, each of
> > which is linked to a root model by a ForeignKey field. That root model
> > looks something like...
>
> > """
> > class Model(models.Model):
> >        title = models.CharField(max_length=300)
> >        fk_1 = models.ForeignKey(fk_1)
> >        fk_2 = models.ForeignKey(fk_2)
> >        fk_3 = models.ForeignKey(fk_3)
>
> >        def __unicode__(self):
> >                return u'%s, %s' % (self.fk_1, self.fk_2)
>
> >        class Meta:
> >                ordering = ['fk_1',]
> > """
>
> > The funny thing is that if I comment out that root model and run
> > dumpdata again, everything goes swimmingly. So I'm guessing the
> > problem is in there somewhere. As I've typed out this entirely too
> > long email, I've started to think and maybe come up with the weird
> > thing I did to screw it up. Would it matter if I initally imported
> > that data outside of Django into the model and maybe stupidly left
> > some of the FK fields null? Well, I think I'm going to go try that
> > right now. If it's something else obvious, please let me know.
>
> Assuming the fields are defined to Django to allow null, and are actually
> null and not, say, 0, then I don't think nulls would cause this problem.
> But it does sound like you've got foreign key values in this table that
> don't actually have corresponding rows in the referenced tables.  I'm
> assuming you've been using MyISAM on MySQL -- it does not enforce
> referential integrity, so you can get into this situation pretty easily with
> adds/upates/deletes done outside of Django's admin.
>
> Karen
--~--~---------~--~----~------------~-------~--~----~
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 [EMAIL PROTECTED]
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to