【发布时间】:2011-10-07 18:29:28
【问题描述】:
我有一张像这样的桌子。
+----+--------+---------+-----------+------------------------+
| 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 和 FIRST 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
如果有人可以清理一下,非常感谢..
【问题讨论】:
-
不清楚您要完成什么。您想从结果集中获取第一项吗?只需使用索引。
-
akonsu - 是的,我想要这组中的第一个唯一“名称”——我最终应该得到三个项目。你能给我一个例子吗?谢谢
-
(Variant.objects.filter(parent=self.id).order_by('name', 'libtype_id')[0]).name 是你要问的吗?我还是不明白……
-
你是这个意思吗? Variant.objects.filter(parent=self.id).order_by('name', 'libtype_id')[0]
-
不,我不想要完整集的第一条记录。我想要每个子集的第一条记录。第一个集合的分组方式是按名称,后跟 libtypeid。我只想要第一个 libtypeid 而不是全部。
标签: mysql django django-queryset