社区所有版块导航
Python
python开源   Django   Python   DjangoApp   pycharm  
DATA
docker   Elasticsearch  
aigc
aigc   chatgpt  
WEB开发
linux   MongoDB   Redis   DATABASE   NGINX   其他Web框架   web工具   zookeeper   tornado   NoSql   Bootstrap   js   peewee   Git   bottle   IE   MQ   Jquery  
机器学习
机器学习算法  
Python88.com
反馈   公告   社区推广  
产品
短视频  
印度
印度  
Py学习  »  Django

django如何找到不在字段中的最小值?

Ahmad • 5 年前 • 2120 次点击  

假设我们有1,2,4,5,6…的记录。。。在表Material中名为Code的字段中。如何写一个ORM返回3,这是不是在现有记录中的最小数量?

Python社区是高质量的Python/Django开发社区
本文地址:http://www.python88.com/topic/52312
 
2120 次点击  
文章 [ 1 ]  |  最新文章 5 年前
Iain Shelvington
Reply   •   1 楼
Iain Shelvington    6 年前

这可以通过使用子查询来完成

all_codes = Material.objects.values('Code')

Material.objects.annotate(
    next=F('Code') + 1
).exclude(
    next__in=all_codes
).aggregate(
    minimum_code=Min('next')
)['minimum_code']

我们发现所有行,其中代码后的下一个数不在所有的代码值中,并且该注释的最小值是表中不存在的最低值。

希望这张表能说明发生了什么

|------|------|--------------------|
| Code | next | next in all Codes? |
|------|------|--------------------|
|   1  |   2  |        True        |
|------|------|--------------------|
|   2  |   3  |        False       |  <- The minimum next not in all codes
|------|------|--------------------|
|   4  |   5  |        True        |
|------|------|--------------------|
|   5  |   6  |        True        |
|------|------|--------------------|
|   6  |   7  |        False       |
|------|------|--------------------|

记住,如果您使用的是MySQL 可怕的 在处理子查询时。在这种情况下,首先计算子查询,然后将结果作为列表传递(如果结果不太大)有时会更快 next__in=list(Material.objects.values_list('Code', flat=True))

这将只给出正确的结果,如果最小值不低于所有现有值,则应首先检查此情况。

minimum_code = Material.objects.aggregate(minimum_code=Min('Code'))['minimum_code']
if minimum_code > 1:  # Or whatever default value you want
    return 1
else:
    # Do the above