zoukankan      html  css  js  c++  java
  • django中的filter详解

    filter (数据过滤)

    我们很少会一次性从数据库中取出所有的数据;通常都只针对一部分数据进行操作。 在Django API中,我们可以使用`` filter()`` 方法对数据进行过滤:

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

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

    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从句, 因此上面的代码可以转化成这样:

    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语句:

    SELECT id, name, address, city, state_province, country, website
    FROM books_publisher
    WHERE name LIKE '%press%';
  • 相关阅读:
    软件构造 第三章第一节 数据类型与类型检查
    类图总结
    【Beta】Scrum07
    【Beta】用户问题反馈及处理(一直更新)
    【Beta】第七次任务发布
    【Beta】Scrum06
    【Beta】第六次任务发布
    【Beta】Scrum5.5
    【Beta】第5.5次任务发布
    【Beta】Scrum05
  • 原文地址:https://www.cnblogs.com/xuchunlin/p/6067103.html
Copyright © 2011-2022 走看看