您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

Python的Django框架中的数据过滤功能

5b51 2022/1/14 8:21:05 python 字数 2297 阅读 482 来源 www.jb51.cc/python

我们很少会一次性从数据库中取出所有的数据;通常都只针对一部分数据进行操作。在DjangoAPI中,我们可以使用``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,website
FROM books_publisher
WHERE country = 'U.S.A.'
AND state_province = 'CA';

注意,sql缺省的 = 操作符是精确匹配的, 其他类型的查找也可以使用:

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

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

SELECT id,website
FROM books_publisher
WHERE name LIKE '%press%';

其他的一些查找类型有:icontains(大小写无关的LIKE),startswith和endswith,还有range(sqlBETWEEN查询)。

总结

以上是编程之家为你收集整理的Python的Django框架中的数据过滤功能全部内容,希望文章能够帮你解决Python的Django框架中的数据过滤功能所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶