многозначное значение - PullRequest
1 голос
/ 18 июня 2011

У меня есть модель mti (Информация о материале), в которой есть список MTD (Описание материала), и в каждом описании описания материала есть размер и цвет.

У меня есть идентификатор MTI, который я хочу получить.весь список значений цветов mymti = mti.objects.get (pk = 1)

как мне получить список цветов из MTI mymti.mtd.color.name?

class color(models.Model):
id = models.AutoField(primary_key=True)
name= models.CharField(max_length=255)
stamp= models.DateTimeField(auto_now=True)
def __unicode__(self):
    return self.name
class mtd(models.Model):
id = models.AutoField(primary_key=True)
barcode = models.CharField(max_length=255)
#mti = models.ManyToManyField(mti)
size = models.ForeignKey(size)
color = models.ForeignKey(color)
weight = models.FloatField()
def __unicode__(self):
    return u'%s - %s %s' % (self.barcode,self.color.name,self.size.name)
class Meta:
    verbose_name = "MTD"
    verbose_name_plural = verbose_name



class mti(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=255)
item = models.ForeignKey(item)
mtd= models.ManyToManyField(mtd)
country = models.ForeignKey(country)
dept = models.ForeignKey(dept)
fabric = models.ForeignKey(fabric)
sesason = models.ForeignKey(season)
sale = models.FloatField()
endUser = models.FloatField()
description = models.TextField(max_length=1000,blank=True,null=True)
year = models.CharField(max_length=255,default=strftime("%Y", gmtime()))
front_page = models.BooleanField(verbose_name="Front Page",default=True)
active = models.BooleanField(default=True)
stamp = models.DateTimeField(auto_now=True)
def __unicode__(self):
    return u'%s - %s' % (self.name, self.description)
class Meta:
    verbose_name = "MTI"
    verbose_name_plural = verbose_name

class mtiimage(models.Model):
id = models.AutoField(primary_key=True)
mtd = models.ManyToManyField(mtd)
image1 = models.ImageField(verbose_name="Product 1 Image",upload_to='product')
image2 = models.ImageField(verbose_name="Product 2 Image",upload_to='product')
image3 = models.ImageField(verbose_name="Product 3 Image",upload_to='product')
stamp = models.DateTimeField(auto_now=True)

def admin_thumbnail(self):
    return u'<img src="%s" heigh="150" width="200" />' % (self.image1.url)
admin_thumbnail.short_description = 'Thumbnail'
admin_thumbnail.allow_tags = True
def __unicode__(self):
    return u'%s ' % (self.id)
class Meta:
    verbose_name = "MTI Image"
    verbose_name_plural = verbose_name

Ответы [ 2 ]

0 голосов
/ 18 июня 2011

Аннотация

Использование аннотации.

mymti = mti.objects.get(pk=1)
unique_colors = mymti.mtd.values_list('color__name', flat=True).annotate()
0 голосов
/ 18 июня 2011
colors = mymti.mtd.values_list('color__name', flat=True).distinct()

приведет к:

colors = [color1, color2, ...]
...