QCon 演讲火热征集中,快来分享技术实践与洞见! 了解详情
写点什么

Django 1.10 提供了 PostgreSQL 中的全文检索功能

  • 2016-08-11
  • 本文字数:1524 字

    阅读完需:约 5 分钟

Django 1.10 版本已经发布,该版本所给出的新特性包括:对 PostgreSQL 数据库的全文检索、Unicode 用户名的官方支持和新型的中间件。

作为 Django 软件基金会的动态语言,该 Django 的重大发布包括了在 django.contrib.postgres.search 模块中对数据库函数调用的功能,这方便了使用 PostgreSQL 的全文检索引擎。

Django 团队给出了例子代码,实现对数据库中某一行数据进行简单搜索。代码如下所示:

复制代码
>>> Entry.objects.filter(body_text__search='Cheese')
[<Entry: Cheese on Toast recipes>, <Entry: Pizza Recipes>]

“代码从数据库的 body_text 域调用一次 _to_tsvector_ 函数,并为检索词‘Cheese’调用一次 _plainto_tsquery_ 函数。这两次函数调用均使用缺省的数据库检索配置。检索结果通过对查询与向量的匹配而得到。为使用该检索查找功能,环境设置 INSTALLED_APPS 中必须包括’django.contrib.postgres’。”

在 Django 文档中,可以查阅到使用 SearchVector SearchQuery SearchRank 类的例子,详细内容参见这里

Django 1.10 版本的新特性还包括引入了一种新型的中间件,该中间件所解决的问题是,“在 DEP 0005 改进建议中提出的旧式中间件中缺乏严格意义上的请求和响应层的问题”。

作为一种“钩入 Django 请求及响应处理的架构”,Django 的新型中间件提供了 django.utils.deprecation.MiddlewareMixin 模块,用于创建与 MIDDLEWARE 和 MIDDLEWARE_CLASSES 兼容的中间件类。

按 Django 文档所述,“该混合类型模块提供了 ___init__()_ 方法,接受 _get_response_ 作为可选参数,并将该参数保存在 _self.get_response_ 中”。对此方法详解如下:

__call__() 方法:

  1. 调用 self.process_request(request) (如果已定义了);
  2. 调用 self.get_response(request),从后续的中间件和视图中获取响应;
  3. 调用 self.process_response(request, response) (如果已定义了);
  4. 返回响应。

在网络上关于 Django 最新发布的新闻得到了很多的肯定,但也一些评论提出了对 Channels 项目的需求。

在 HackerNew 网站对“Django 1.10 发布了”的讨论中,用户 Tom Forbes 是这样评论的:“Channels 项目真是可耻呀,我发现新版本中并没有包含这个项目”。而用户 ubernostrum 是这样回复的:“Channel 项目将会取得成功的。它只是尚未准备好在1.10 版本中发布。希望它会在1.11 版本中准备好,并将在Django 中启用。”

用户 passiveincomelg 给出了不太确定的说法:“我对Channel 的态度有些矛盾。一方面,使用它所能做的事情是很酷的,它的设计十分聪明地避免了重写所有Django 程序为异步的。另一方面,为实现这个Go 和Erlang 所轻易实现的功能,还有要去完成多少的恶作剧,这真是令人抓狂。”

Django 1.10 版还包括一些不向后兼容的改进。而也有一些特性在达到其弃用周期后,也已经被弃用

这些被弃用的特性包括:在LOGIN_URL 和LOGIN_REDIRECT_URL 中设置使用可带点的Python 路径;django.core.context_processors、django.db.models.sql.aggregates 和django.contrib.gis.db.models.sql.aggregates 等模块;为使用SQLCompiler 的quote_name_unless_alias 方法而支持用别名方式直接调用SQLCompiler;以及其它一些私有API。

作为一种用Python 编写的自由开源Web 应用框架,Django 以三句版BSD 协议发布,它欢迎来自InfoQ 社区的贡献。

任何寻求改进和对Django 有所贡献的人,可以访问 docs.djangoproject.com/en/dev/internals/contributing/ .

查看英文原文: Django 1.10 Brings Full Text Search for PostgreSQL


感谢张龙对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2016-08-11 19:002125
用户头像

发布了 227 篇内容, 共 75.6 次阅读, 收获喜欢 28 次。

关注

评论

发布
暂无评论
发现更多内容

synchronized 优化手段之锁膨胀机制!

王磊

Java 并发 8月日更

netty系列之:netty初探

程序那些事

Java 响应式编程 Netty nio 程序那些事

kafka SpringBoot

Rubble

kafka springboot 8月日更

Rust从0到1-模式-可反驳性

rust 模式 Patterns Refutability 可反驳性

Python OpenCV 图像区域轮廓标记,可用于框选各种小纸条

梦想橡皮擦

8月日更

【Flutter 专题】132 图解 PaginatedDataTable 分页表格

阿策小和尚

Flutter 小菜 0 基础学习 Flutter Android 小菜鸟 8月日更

多语言ASR?没有什么听不懂,15种语言我全都要

华为云开发者联盟

语言 ASR 多语言ASR 单语模型 Conformer

原来select语句在MySQL中是这样执行的!看完又涨见识了!这回我要碾压面试官!

冰河

MySQL 面试 精通MySQL SELECT查询流程 查询缓存

Druid 通过 dsql 运行的时候提示错误 urllib2

HoneyMoose

【设计模式】原型

Andy阿辉

C# 编程 后端 设计模式 8月日更

【Maven技术专题】如何使用Assembly插件实现自定义打包

洛神灬殇

maven assembly 8月日更

索信达控股:银行4.0的AI世界——开启算法力的时代

索信达控股

人工智能 金融科技 银行

分布式性能测试框架用例方案设想(二)

FunTester

分布式 性能测试 接口测试 测试框架 测试开发

Druid 从控制台(Druid console)中删除过滤器和运行查询

HoneyMoose

深度学习中的分布式训练

安第斯智能云

人工智能 深度学习

重磅 | 用友《数字化中台》震撼上市!数智化转型和商业创新实践的企业级经验!

博文视点Broadview

PostgreSQL 中如何控制行级安全和列级安全

Qunar技术沙龙

sql postgresql 运维 安全 权限

基于ECS快速搭建 Docker 环境

若尘

Docker 服务器 8月日更

鸿蒙内核之内存调测:动态内存池信息统计

华为云开发者联盟

鸿蒙 内存 动态内存池 内存信息

一文带你搞定AOP切面

华为云开发者联盟

spring aop 切面编程 面向切面编程 切面

Design for failure常见的12种设计思想

架构精进之路

降级 重试 容错 8月日更

Python代码阅读(第1篇):列表映射后的平均值

Felix

Python 编程 Code Programing 阅读代码

docker入门:postgresql安装及可视化界面portainer使用

小鲍侃java

8月日更

复杂多变场景下的Groovy脚本引擎实战

vivo互联网技术

敏捷开发 脚本语言

百度爱番番移动端网页秒开实践

百度Geek说

大前端 优化 网页加速 移动端

Springboot 配置文件、隐私数据脱敏的最佳实践(原理+源码)

程序员小富

Java springboot 数据安全 数据脱敏

Druid 的几个查询实例

HoneyMoose

十大排序算法--插入排序

Ayue、

排序算法 8月日更

手撸二叉树之对称二叉树

HelloWorld杰少

算法和数据结构 8月日更

基于docker的分布式性能测试框架功能验证(二)

FunTester

分布式 性能测试 接口测试 测试框架 测试开发

Druid 从控制台(Druid console)从 SQL 脚本转换为 JSON 格式的方法

HoneyMoose

Django 1.10提供了PostgreSQL中的全文检索功能_Python_James Chesters_InfoQ精选文章