SQLALCHEMY 忽略查询中的重音符号

2024-02-27

考虑到我的用户可以将数据保存为“café”或“cafe”,我需要能够使用不区分重音的查询来搜索该字段。

我发现了https://github.com/djcoin/django-unaccent/ https://github.com/djcoin/django-unaccent/,但我不知道是否可以在 sqlalchemy 上实现类似的东西。

我正在使用 PostgreSQL,因此如果解决方案特定于该数据库对我来说是有好处的。如果它是通用解决方案,那就好得多。

感谢您的帮助。


首先安装unaccent https://www.postgresql.org/docs/current/unaccent.htmlPostgreSQL 中的扩展create extension unaccent;

接下来,声明 SQL 函数unaccent在Python中:

from sqlalchemy.sql.functions import ReturnTypeFromArgs

class unaccent(ReturnTypeFromArgs):
    pass

并像这样使用它:

for place in session.query(Place).filter(unaccent(Place.name) == "cafe").all():
    print place.name

如果您有一个大表,请确保您有正确的索引,否则这将导致全表扫描。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

SQLALCHEMY 忽略查询中的重音符号 的相关文章

随机推荐

  • exec sp_updatestats 的作用是什么?

    有什么用sp updatestats 我可以在生产环境中运行它以提高性能吗 sp updatestats更新数据库中所有表的所有统计信息 甚至单行已更改 它使用默认示例来执行此操作 这意味着它不会扫描表中的所有行 因此它可能会生成不如替代方
  • 如何从两个制表符分隔的文件中获取枢轴线?

    给定两个文件file1 txt abc def t 123 456 jkl mno t 987 654 foo bar t 789 123 bar bar t 432 and file2 txt foo bar t hello world
  • 更新具有空值的多行

    我有一个包含 id 和 name 两列的表 Id 包含空值 name 包含一些名称值 表中存在重复的行 要求是将空值 id 更新为与名称值匹配的某个值 查找下表 Id Name 1 abc 1 abc 1 abc 1 abc NULL ab
  • 将表重新添加到实体模型 (edmx) 时不显示

    我有一个有 5 个表的数据库 一开始 我添加了这些表 但后来由于某些关系编译错误而决定删除一些表 现在 当我想将它们添加回来时 我打开 edmx 文件 gt 从数据库更新模型 我在 添加 选项卡下看不到这些表 而只在 刷新 选项卡下看到 我
  • Tensorflow:张量到 numpy 数组的转换,无需运行任何会话

    我在张量流中创建了一个OP 对于某些处理 我需要将数据从张量对象转换为numpy数组 我知道我们可以使用tf eval or sess run评估任何张量对象 我真正想知道的是 有没有办法在不运行任何会话的情况下将张量转换为数组 因此我们又
  • 映射类型:删除私有接口

    在 TypeScript 中 私有属性被视为类型的形状 或接口 的一部分 class Person constructor private name string public age number const p Person age 4
  • Android Studio:在当前行显示错误的键盘快捷键?

    我发现显示带下划线的代码段错误的唯一方法是将鼠标悬停在其上 实现此目的的键盘快捷键是什么 当光标位于错误行时 在 Mac 上是 Command F1 在菜单栏中是 查看 gt 错误描述 我认为这就是 Windows 上的 Control F
  • APNS 从多个服务器发送通知

    我正在编写一个 iOS 应用程序 它将通过 APNS 从后端服务器发送通知 我可以配置多个服务器来连接到 APNS 并发送通知吗 如果是这样 可以为单个应用程序发送通知的服务器数量是否有限制 我在 Apple 网站上找不到有关此内容的任何详
  • Spring框架,启用PUT方法

    我在捕获发送到服务器的 PUT 请求时遇到问题 这些是我的方法 RequestMapping method RequestMethod GET public String getCity PathVariable value cid Str
  • Webpack 开发服务器不自动重新加载

    所以我设置了 webpack 并webpack dev server but webpack dev server不自动重新加载 如果我修改文件并保存它 则浏览器中不会发生任何更改 直到我手动刷新 这是我的 webpack 配置和运行的脚本
  • 如何为 nltk 词形还原器提供(或生成)标签

    我有一组文档 我想将它们转换为这样的形式 这样我就可以对这些文档中的单词进行 tfidf 计数 这样每个文档都由 tfidf 数字向量表示 我认为调用 WordNetLemmatizer lemmatize word 就足够了 然后调用 P
  • SwiftUI:自动预览更新始终暂停

    我有一个现有的应用程序 基本上是一个购物清单应用程序 我试图向其中添加一些甜蜜的 SwiftUI 爱 我的问题是实时预览更新不起作用 不断显示警告 自动预览更新已暂停 我点击了恢复按钮 它构建了应用程序 它显示了当前视图 并且该警告立即再次
  • 警告消息:在“...”中:因子水平无效,生成 NA

    我不明白为什么我收到此警告消息 gt fixed lt data frame Type character 3 Amount numeric 3 gt fixed 1 lt c lunch 100 Warning message In lt
  • Prestashop Web 服务 API 不断要求身份验证

    我遇到这个问题 我从 prestashop 启用了 web 服务 如果我编写 URL 直接从 post 方法传递参数 我可以访问它 mykey 但是 如果我尝试在不传递 ws key 作为参数的情况下进行访问 它会一直要求我进行身份验证 从
  • JavaScript 扩展类

    我有一个基类 function Monster this health 100 Monster prototype growl function console log Grr 我想扩展并创建另一个类 function Monkey ext
  • 如何以编程方式停止 Windows 服务

    关于Windows服务编程 如何停止我的Windows服务 这是一个非常简化的示例代码 C Here is my service class MyTestService cs public class MyTestService Servi
  • 如何使用 Valgrind 检测分段错误细节?

    我有一个 std map 它通过一些 API 调用进行初始化 当我尝试使用此地图时 出现分段错误 如何检测无效代码或无效内容或任何可以帮助我解决问题的细节 代码如下所示 std map lt std string std string gt
  • 在 SwiftUI 中,如何增加按钮的高度?

    正如您在屏幕截图中看到的 按钮高度没有调整以适应文本大小 使其看起来很丑 我怎样才能增加按钮的高度 这样它看起来就不傻了 我的问题是 如何增加 SwiftUI 中按钮的高度 我正在尝试制作类似 Minecraft 的游戏的标题屏幕 stru
  • 将电子邮件设置为 IMAP 服务器上的“已查看”

    我正在尝试从 Imap 服务器 Gmail 读取邮件 我会检查是否有新邮件 未见 并按所见进行检查 我写了这段代码但是 imap setflag full 似乎不起作用 如果我有一封新邮件 则脚本无法放置 SEEN 标志 并且它回显我总是有
  • SQLALCHEMY 忽略查询中的重音符号

    考虑到我的用户可以将数据保存为 caf 或 cafe 我需要能够使用不区分重音的查询来搜索该字段 我发现了https github com djcoin django unaccent https github com djcoin dja