Thanks Max. In an ideal world left_connector, right_connector would be the way to go. However, I need to account for a cable that, at one or both ends is split into separate conductors, that go to separate connectors (thus breaking the rule I had specified.) Nodes, with a little embellishment, allow me to achieve this. I will investigate your itertools suggestion.
Mike On Oct 20, 8:38 am, Max Battcher <m...@worldmaker.net> wrote: > adelaide_mike wrote: > > Hi > > My models are, essentially : > > class Cable(models.Model): > > cable = models.CharField(max_length=8) > > > class Connector(models.Model): > > connector = models.CharField(max_length=8) > > > class Node(models.Model): > > cable = models.ForeignKey(Cable) > > connector = models ForeignKey(Connector) > > > So, a real world cable can be plugged in to no, one, or two connectors > > (one at each end). The Node table describes the junctions between > > cables and connectors. > > > Can I, without resorting to raw SQL, build a queryset that shows > > connector-cable-connector? > > You would have a hard time even accomplishing that in raw SQL with those > models... If you have the flexibility to change your models I would try > something like: > > class Connector(models.Model): > name = models.CharField(max_length=8) > > class Cable(models.Model): > name = models.CharField(max_length-8) > left_connector = models.ForeignKey(Connector, blank=True, null=True) > right_connector = models.ForeignKey(Connector, blank=True, null=True) > > This makes your 0, 1, or 2 relationship explicit. I went with the > left/right distinction as it is an easy "handed" way of describing them, > but other choices may be more appropriate depending on your usage > patterns... > > Otherwise, your best bet would seem to me to be to use > Node.objects.all().orderby('cable') and group the > connector-cable-connector by yourself. Something that I generally find > useful in situations like that is Python's groupby function from itertools. > > -- > --Max Battcher--http://worldmaker.net --~--~---------~--~----~------------~-------~--~----~ 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 -~----------~----~----~----~------~----~------~--~---