Упростите мою Django Query Logic - PullRequest
       2

Упростите мою Django Query Logic

0 голосов
/ 07 октября 2011

У меня есть таблица, которая выглядит следующим образом.

+----+--------+---------+-----------+------------------------+
| id | parent | type    | libTypeId | name                   |
+----+--------+---------+-----------+------------------------+
|  2 |      1 | project |         2 | 1p6m4x0y1z_1.2-1.8_hvt |
|  5 |      1 | project |         6 | 1p6m4x0y1z_1.2-1.8_hvt |
|  8 |      1 | project |        16 | 1p6m4x0y1z_1.2-1.8_hvt |
| 11 |      1 | project |        21 | 1p6m4x0y1z_1.2-1.8_hvt |
|  3 |      1 | project |         2 | 1p6m4x0y1z_1.2-1.8_lvt |
|  6 |      1 | project |         6 | 1p6m4x0y1z_1.2-1.8_lvt |
|  9 |      1 | project |        16 | 1p6m4x0y1z_1.2-1.8_lvt |
| 12 |      1 | project |        21 | 1p6m4x0y1z_1.2-1.8_lvt |
|  1 |      1 | project |         2 | 1p6m4x0y1z_1.2-1.8_svt |
|  4 |      1 | project |         6 | 1p6m4x0y1z_1.2-1.8_svt |
|  7 |      1 | project |        16 | 1p6m4x0y1z_1.2-1.8_svt |
| 10 |      1 | project |        21 | 1p6m4x0y1z_1.2-1.8_svt |
| 13 |      2 | project |         2 | 065nm_GPIO             |
| 17 |      2 | project |         4 | 065nm_GPIO             |
| 14 |      2 | project |         6 | 065nm_GPIO             |
| 18 |      2 | project |        12 | 065nm_GPIO             |
| 15 |      2 | project |        16 | 065nm_GPIO             |
| 16 |      2 | project |        21 | 065nm_GPIO             |
| 19 |      2 | project |         2 | 065nm_Specialized      |
+----+--------+---------+-----------+------------------------+

Я ищу запрос, который приводит к списку, в который мы получаем все проекты с id = 1, который отсортирован по имени, libtypeidи только ПЕРВЫЙ libtypeid.

Другими словами, я должен закончить с этим:

+----+--------+---------+-----------+------------------------+
| id | parent | type    | libTypeId | name                   |
+----+--------+---------+-----------+------------------------+
|  2 |      1 | project |         2 | 1p6m4x0y1z_1.2-1.8_hvt |
|  3 |      1 | project |         2 | 1p6m4x0y1z_1.2-1.8_lvt |
|  1 |      1 | project |         2 | 1p6m4x0y1z_1.2-1.8_svt |
+----+--------+---------+-----------+------------------------+

Теперь я могу получить это далеко, но как мне получить только первый ??

Variant.objects.filter(parent=self.id).order_by('name', 'libtype_id')

Затем я сделаю это еще раз ..

full = Variant.objects.filter(parent=self.id).order_by('name', 'libtype_id')
names, out = [], []
for v in full:
    if v.name not in names:
       out.append(v)
       names.append(v.name)
return out

Буду очень признателен, если кто-нибудь сможет это немного почистить ..

Ответы [ 3 ]

1 голос
/ 08 октября 2011

если я правильно понимаю вопрос, вам нужно «сгруппировать» ваш набор и вернуть первый ряд из каждой группы. вам нужно взглянуть на агрегацию: https://docs.djangoproject.com/en/dev/topics/db/aggregation/

что-то вроде Variant.objects .values('name', 'libtype_id') .annotate(min_libtype_id=Min('libtype_id')) .filter(parent=self.id) это не проверено .

0 голосов
/ 13 июля 2012

Вот ответ, который я искал ..

class VariantQuerySet(QuerySet):
    def as_single_library_type(self):
        query = self.filter().query
        query.group_by = ['name']
        return QuerySet(self.model, using=self._db, query=query)

class VariantManager(models.Manager):

    def get_query_set(self):
        return VariantQuerySet(self.model, using=self._db)

В основном это значение по умолчанию GROUP BY, которое сводит все к тому, что мне нужно.Спасибо всем, кто попытался ответить!

0 голосов
/ 08 октября 2011

Вы можете добавить [number] к набору запросов, например:

Variant.objects.filter(parent=self.id).order_by('name', 'libtype_id')[0]

, который возвращает первую запись в наборе запросов.Чтобы получить последний, это будет [:0], двоеточие меняет местами соединение.

...