在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()); } } }查询可能会变慢,因为它具有更多结果,或者不区分大小写的比较需要更多的精力。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...