在postgres中创建不区分大小写的trigram-index的正确方法是什么?

如何解决在postgres中创建不区分大小写的trigram-index的正确方法是什么?

...这是我应该做的吗?

通过我的简短测试,制作了三字母组合索引并使用进行搜索

where name like '%query%'

where name ilike '%query%'

所以看来我应该这样做,但令我惊讶的是我还没有找到方法

(我的测试数据相当均匀-由16个条目重复组成的150万行。我可以想象这可能会干扰结果。)

这是我期望它工作的方式(请注意lower(name)):

create extension pg_trgm;

create table users(name text);

insert into users values('Barry');

create index "idx" on users using gin (lower(name) gin_trgm_ops);

select count(*) from users where (name like '%bar%');

但这返回0

任何一个

select count(*) from users where (name like '%Bar%');

select count(*) from users where (name ilike '%bar%');

工作,这使我相信索引中的三元组没有lower()。我是不是误会了它的工作原理?不可能在那里打lower吗?

我注意到这个

select show_trgm('Barry')

返回小写字母三元组

{"  b"," ba",arr,bar,rry,"ry "}

所以我很困惑。

解决方法

三元组绝对是小写。

当您考虑如何使用Trigram索引时,难题就变得清晰了:它们充当了消除大多数不匹配项的过滤器,但允许出现假阳性结果(其他原因是它们不区分大小写)。这就是为什么总是需要重新检查以消除那些误报的原因,也是我们为什么总是获得位图索引扫描的原因。

// solve by adding \Cartalyst\Stripe\Exception\ in // catch(\Cartalyst\Stripe\Exception\CardErrorException $e) <?php namespace App\Http\Controllers; use Cartalyst\Stripe\Laravel\Facades\Stripe; use Illuminate\Http\Request; use Illuminate\Support\Facades\Redirect; class BuyNowController extends Controller { public function buyNow(Request $request) { try { $charge = Stripe::charges()->create([ 'amount' => $request->total,'currency' => 'CAD','source' => $request->stripeToken,'description' => 'Description goes here','receipt_email' => $request->email,'metadata' => [ 'country'=>$request->country,'address'=>$request->address,'postal code'=>$request->postalcode,'data1' => 'metadata 1','data2' => 'metadata 2','data3' => 'metadata 3',],]); } // solve by addind \Cartalyst\Stripe\Exception\ before ecxeption name catch (\Cartalyst\Stripe\Exception\CardErrorException $e) { // save info to database for failed return back()->withErrors('Error! ' . $e->getMessage()); } } }查询可能会变慢,因为它具有更多结果,或者不区分大小写的比较需要更多的精力。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?