问题描述
...这是我应该做的吗?
通过我的简短测试,制作了三字母组合索引并使用进行搜索
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());
}
}
}
查询可能会变慢,因为它具有更多结果,或者不区分大小写的比较需要更多的精力。