django中的filter详解

filter (数据过滤)

咱们不多会一次性从数据库中取出全部的数据;一般都只针对一部分数据进行操做。 在Django API中,咱们能够使用`` filter()`` 方法对数据进行过滤:python

>>> Publisher.objects.filter(name='Apress')
[<Publisher: Apress>]

filter() 根据关键字参数来转换成 WHERE SQL语句。 前面这个例子 至关于这样:web

SELECT id, name, address, city, state_province, country, website
FROM books_publisher
WHERE name = 'Apress';

 你能够传递多个参数到 filter() 来缩小选取范围:数据库

>>> Publisher.objects.filter(country="U.S.A.", state_province="CA")
[<Publisher: Apress>]

多个参数会被转换成 AND SQL从句, 所以上面的代码能够转化成这样:spa

SELECT id, name, address, city, state_province, country, website
FROM books_publisher
WHERE country = 'U.S.A.'
AND state_province = 'CA';

注意,SQL缺省的 = 操做符是精确匹配的, 其余类型的查找也能够使用:翻译

>>> Publisher.objects.filter(name__contains="press")
[<Publisher: Apress>]

namecontains 之间有双下划线。和Python同样,Django也使用双下划线来代表会进行一些魔术般的操做。这里,contains部分会被Django翻译成LIKE语句:code

SELECT id, name, address, city, state_province, country, website
FROM books_publisher
WHERE name LIKE '%press%';
相关文章
相关标签/搜索