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

系统 1895 0

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

            
>>> Publisher.objects.filter(name='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")
[
            
              ]


            
          

多个参数会被转换成 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")
[
            
              ]


            
          

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

            
SELECT id, name, address, city, state_province, country, website
FROM books_publisher
WHERE name LIKE '%press%';


          

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


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论