什么是更有效的.objects.filter().exists()或get()包装在一个尝试

Abr*_*ham 13 python testing django django-models

我正在为django应用程序编写测试,我想检查一个对象是否已保存到数据库中.哪种方法最有效/最正确?

User.objects.filter(username=testusername).exists()
Run Code Online (Sandbox Code Playgroud)

要么

try:
    User.objects.get(username=testusername)
except User.DoesNotExist:
Run Code Online (Sandbox Code Playgroud)

pco*_*nel 16

速度测试:exists()vs.get() + try/except

test.py中的测试函数:

from testapp.models import User

def exists(x):
    return User.objects.filter(pk=x).exists()

def get(x):
    try:
        User.objects.get(pk=x)
        return True
    except User.DoesNotExist:
        return False
Run Code Online (Sandbox Code Playgroud)

在shell中使用timeit:

In [1]: from testapp import test
In [2]: %timeit for x in range(100): test.exists(x)
10 loops, best of 3: 88.4 ms per loop
In [3]: %timeit for x in range(100): test.get(x)
10 loops, best of 3: 105 ms per loop
In [4]: timeit for x in range(1000): test.exists(x)
1 loops, best of 3: 880 ms per loop
In [5]: timeit for x in range(1000): test.get(x)
1 loops, best of 3: 1.02 s per loop
Run Code Online (Sandbox Code Playgroud)

结论:exists()快10%以上的对象是否被保存在数据库中检查.


Dan*_*man 6

如果您不需要用户,则第一个更有效,因为它不实例化对象.