手机
当前位置:查字典教程网 >脚本专栏 >python >Python的Django框架中的数据过滤功能
Python的Django框架中的数据过滤功能
摘要:我们很少会一次性从数据库中取出所有的数据;通常都只针对一部分数据进行操作。在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, 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>]

在 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查询)。

【Python的Django框架中的数据过滤功能】相关文章:

Python写的Discuz7.2版faq.php注入漏洞工具

Python的一些用法分享

Python enumerate遍历数组示例应用

python list使用示例 list中找连续的数字

python两种遍历字典(dict)的方法比较

Python常见数据结构详解

Python ORM框架SQLAlchemy学习笔记之数据查询实例

Python def函数的定义、使用及参数传递实现代码

python的id()函数介绍

Python的词法分析与语法分析

精品推荐
分类导航