Python的Django框架中的数据过滤功能
2015-07-17 10:42
756 查看
我们很少会一次性从数据库中取出所有的数据;通常都只针对一部分数据进行操作。 在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框架中forms表单类的使用方法详解
- 使用PyCharm配合部署Python的Django框架的配置纪实
- Django框架如何使用ajax的post方法
- 全面解读Python Web开发框架Django
- 分析Python的Django框架的运行方式及处理流程
- 详解Python的Django框架中manage命令的使用与扩展
- 详解Python的Django框架中Manager方法的使用
- Python的Django框架中的表单处理示例
- 使用Python的Django框架实现事务交易管理的教程
- 在Python的Django框架中更新数据库数据的方法
- Django开发中复选框用法示例
相关文章推荐
- windows+apache+mod_python配置django运行环境
- python Django连接MySQL数据库做增删改查
- django自定义Field实现一个字段存储以逗号分隔的字符串
- 在Python的Django框架中加载模版的方法
- Python中DJANGO简单测试实例
- Python的Django框架中的数据库配置指南
- 使用Python的Django框架中的压缩组件Django Compressor
- 对于Python的Django框架部署的一些建议
- Python的Django框架中的Context使用
- 详解Python的Django框架中的templates设置
- Django中处理出错页面的方法
- Django框架中方法的访问和查找
- Django中模型Model添加JSON类型字段的方法
- python中django框架通过正则搜索页面上email地址的方法
- Python的Django框架中的URL配置与松耦合
- Python中下划线的使用方法
- 在Python的Django框架下使用django-tagging的教程
- Django集成百度富文本编辑器uEditor攻略
- 开始着手第一个Django项目
- 详解Django中的ifequal和ifnotequal标签使用