婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PostgreSQL模糊匹配走索引的操作

PostgreSQL模糊匹配走索引的操作

熱門標簽:400電話申請客服 濟南外呼網(wǎng)絡(luò)電話線路 電銷機器人能補救房產(chǎn)中介嗎 電話機器人怎么換人工座席 廣州電銷機器人公司招聘 江蘇400電話辦理官方 移動外呼系統(tǒng)模擬題 地圖標注要花多少錢 天津開發(fā)區(qū)地圖標注app

場景 lower(name) like 'pf%'

create table users (id int primary key, name varchar(255));
Create or replace function random_string(length integer) returns text as
$$
declare
 chars text[] := '{0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z}';
 result text := '';
 i integer := 0;
begin
 if length  0 then
 raise exception 'Given length cannot be less than 0';
 end if;
 for i in 1..length loop
 result := result || chars[1+random()*(array_length(chars, 1)-1)];
 end loop;
 return result;
end;
$$ language plpgsql;
insert into users values(generate_series(1,50000), random_string(15));

普通bt:不走索引

pg_trgm模塊提供函數(shù)和操作符測定字母數(shù)字文本基于三元模型匹配的相似性,還有支持快速搜索相似字符串的索引操作符類。三元模型是一組從一個字符串中獲得的三個連續(xù)的字符。我們可以通過計數(shù)兩個字符串共享的三元模型的數(shù)量來測量它們的相似性。這個簡單的想法證明在測量許多自然語言詞匯的相似性時是非常有效的。

CREATE INDEX users_idx0 ON users (name);

全字匹配查詢(走索引)

explain select * from users where name='pfDNQVmhqDrF1EY';
        QUERY PLAN
-------------------------------------------------------------------------
 Index Scan using users_idx0 on users (cost=0.29..8.31 rows=1 width=20)
 Index Cond: ((name)::text = 'pfDNQVmhqDrF1EY'::text)
(2 rows)

加函數(shù)全字匹配(不走索引)

explain select * from users where lower(name)='pfDNQVmhqDrF1EY';
      QUERY PLAN
-----------------------------------------------------------
 Seq Scan on users (cost=0.00..1069.00 rows=250 width=20)
 Filter: (lower((name)::text) = 'pfDNQVmhqDrF1EY'::text)
(2 rows)

模糊匹配(不走索引)

explain select * from users where name like 'pf%';
      QUERY PLAN
--------------------------------------------------------
 Seq Scan on users (cost=0.00..944.00 rows=5 width=20)
 Filter: ((name)::text ~~ 'pf%'::text)
explain select * from users where name like 'pf_';
      QUERY PLAN
--------------------------------------------------------
 Seq Scan on users (cost=0.00..944.00 rows=5 width=20)
 Filter: ((name)::text ~~ 'pf_'::text)

字段帶函數(shù)的bt索引:函數(shù)走索引

drop index users_idx0;
CREATE INDEX users_dex1 ON users (lower(name));

加函數(shù)全字匹配(走索引)

explain select * from users where lower(name)='pfDNQVmhqDrF1EY';
        QUERY PLAN
---------------------------------------------------------------------------
 Bitmap Heap Scan on users (cost=6.23..324.34 rows=250 width=20)
 Recheck Cond: (lower((name)::text) = 'pfDNQVmhqDrF1EY'::text)
 -> Bitmap Index Scan on users_dex1 (cost=0.00..6.17 rows=250 width=0)
   Index Cond: (lower((name)::text) = 'pfDNQVmhqDrF1EY'::text)
(4 rows)

模糊匹配(不走索引)

explain select * from users where lower(name) like 'pf%';
      QUERY PLAN
-----------------------------------------------------------
 Seq Scan on users (cost=0.00..1069.00 rows=250 width=20)
 Filter: (lower((name)::text) ~~ 'pf%'::text)
(2 rows)

聲明操作符類的bt索引:like走索引

定義索引的同時可以為索引的每個字段聲明一個操作符類。

CREATE INDEX name ON table (column opclass [sort options] [, …]);

這個操作符類指明該索引用于該字段時要使用的操作符。

CREATE INDEX users_dex2 ON users (lower(name) varchar_pattern_ops);

模糊匹配(走索引)

explain select * from users where lower(name) like 'pf%';
            QUERY PLAN
------------------------------------------------------------------------------------------------------
 Bitmap Heap Scan on users (cost=4.82..144.00 rows=5 width=20)
 Filter: (lower((name)::text) ~~ 'pf%'::text)
 -> Bitmap Index Scan on users_dex2 (cost=0.00..4.82 rows=53 width=0)
   Index Cond: ((lower((name)::text) ~>=~ 'pf'::text) AND (lower((name)::text) ~~ 'pg'::text))
(4 rows)

場景2 name like '%pf%'

Create or replace function random_string(length integer) returns text as
$$
declare
 chars text[] := '{0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z}';
 result text := '';
 i integer := 0;
begin
 if length  0 then
 raise exception 'Given length cannot be less than 0';
 end if;
 for i in 1..length loop
 result := result || chars[1+random()*(array_length(chars, 1)-1)];
 end loop;
 return result;
end;
$$ language plpgsql;
create table users (id int primary key, name varchar(255));
insert into users values(generate_series(1,50000), random_string(15));

聲明操作符bt:不走索引

CREATE INDEX idx_name ON users USING btree (lower(name) varchar_pattern_ops);
explain (analyze true,format yaml, verbose true, buffers true) select * from users where lower(name) like '%pf%';\

      QUERY PLAN
-----------------------------------------------------------
 - Plan:             +
  Node Type: "Seq Scan"        +
  Parallel Aware: false        +
  Relation Name: "users"        +
  Schema: "public"          +
  Alias: "users"          +
  Startup Cost: 0.00         +
  Total Cost: 1069.00         +
  Plan Rows: 5           +
  Plan Width: 20          +
  Actual Startup Time: 0.320       +
  Actual Total Time: 86.841       +
  Actual Rows: 710          +
  Actual Loops: 1          +
  Output:            +
  - "id"            +
  - "name"           +
  Filter: "(lower((users.name)::text) ~~ '%pf%'::text)"+
  Rows Removed by Filter: 49290      +
  Shared Hit Blocks: 319        +
  Shared Read Blocks: 0        +
  Shared Dirtied Blocks: 0        +
  Shared Written Blocks: 0        +
  Local Hit Blocks: 0         +
  Local Read Blocks: 0         +
  Local Dirtied Blocks: 0        +
  Local Written Blocks: 0        +
  Temp Read Blocks: 0         +
  Temp Written Blocks: 0        +
 Planning Time: 0.188         +
 Triggers:            +
 Execution Time: 86.975

聲明pg_trgm操作符bt:可以走索引

CREATE EXTENSION pg_trgm;
CREATE INDEX idx_users_name_trgm_gist ON users USING gist (name gist_trgm_ops);
explain (analyze true, verbose true, buffers true) select * from users where name like '%pf%';
                QUERY PLAN
------------------------------------------------------------------------------------------------------------------------------------------
 Bitmap Heap Scan on public.users (cost=32.19..371.08 rows=505 width=20) (actual time=19.314..53.132 rows=193 loops=1)
 Output: id, name
 Recheck Cond: ((users.name)::text ~~ '%pf%'::text)
 Rows Removed by Index Recheck: 49807
 Heap Blocks: exact=319
 Buffers: shared hit=972
 -> Bitmap Index Scan on idx_users_name_trgm_gist (cost=0.00..32.06 rows=505 width=0) (actual time=19.175..19.175 rows=50000 loops=1)
   Index Cond: ((users.name)::text ~~ '%pf%'::text)
   Buffers: shared hit=653
 Planning time: 0.188 ms
 Execution time: 53.231 ms
(11 rows)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • PostgreSQL之INDEX 索引詳解
  • PostgreSql 重建索引的操作
  • postgresql查看表和索引的情況,判斷是否膨脹的操作
  • PostgreSQL的B-tree索引用法詳解
  • postgresql通過索引優(yōu)化查詢速度操作
  • postgresql 索引之 hash的使用詳解

標簽:寶雞 榆林 溫州 濮陽 海西 辛集 昭通 杭州

巨人網(wǎng)絡(luò)通訊聲明:本文標題《PostgreSQL模糊匹配走索引的操作》,本文關(guān)鍵詞  PostgreSQL,模糊,匹配,走,索引,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PostgreSQL模糊匹配走索引的操作》相關(guān)的同類信息!
  • 本頁收集關(guān)于PostgreSQL模糊匹配走索引的操作的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91看片淫黄大片一级在线观看| 调教+趴+乳夹+国产+精品| 本田岬高潮一区二区三区| 欧美一区二区三区视频| 亚洲黄色小说网站| 91视频.com| 亚洲一区免费在线观看| 色94色欧美sute亚洲线路一ni| 欧美国产精品一区| 久久福利资源站| 精品欧美一区二区三区精品久久| 日韩精品亚洲一区二区三区免费| 欧美亚洲国产bt| 天天亚洲美女在线视频| 欧美无砖砖区免费| 日韩中文字幕麻豆| 精品国产1区二区| 日韩av二区在线播放| 欧美精品v国产精品v日韩精品| 亚洲国产精品视频| 欧美吻胸吃奶大尺度电影 | 亚洲精品美腿丝袜| 欧美日韩国产成人在线91| 国产精品第13页| 国产色产综合产在线视频| 国产成人免费视频网站高清观看视频| 日韩亚洲欧美在线| 国产精品一卡二卡在线观看| 亚洲精品欧美专区| 91麻豆精品国产| 91影院在线观看| 蜜桃一区二区三区在线观看| 国产午夜精品久久久久久久| 99视频精品全部免费在线| 免费人成在线不卡| 樱桃国产成人精品视频| 久久精品欧美一区二区三区麻豆| 一本一道久久a久久精品综合蜜臀| 日韩和欧美一区二区| 中文字幕中文字幕在线一区| 日韩精品自拍偷拍| 欧美日韩激情一区二区三区| av日韩在线网站| 91网站在线观看视频| 成人在线视频一区二区| 蜜臀久久99精品久久久画质超高清| 亚洲素人一区二区| 中文字幕制服丝袜一区二区三区 | 毛片一区二区三区| 免费精品视频在线| 精品无码三级在线观看视频| 蜜臀久久99精品久久久画质超高清| 亚洲国产日韩一级| 午夜久久电影网| 卡一卡二国产精品| 91在线视频播放| 欧美va亚洲va国产综合| 91麻豆精品视频| 欧美色网站导航| 欧美丰满少妇xxxxx高潮对白| 精品视频999| 精品国产一区二区精华| 国产色一区二区| 久久亚洲一级片| 亚洲久草在线视频| 五月激情六月综合| 国产精品亚洲午夜一区二区三区 | 国产成人99久久亚洲综合精品| 99精品国产热久久91蜜凸| 欧美少妇一区二区| 日韩网站在线看片你懂的| 久久久国际精品| 午夜久久福利影院| 成人性生交大片免费看中文网站| 欧洲激情一区二区| 久久精品综合网| 青青国产91久久久久久| av成人免费在线观看| 久久久久久久综合狠狠综合| 亚洲一区影音先锋| 99在线精品视频| 国产网站一区二区| 免费成人在线播放| 欧美日韩电影一区| 亚洲国产另类精品专区| 本田岬高潮一区二区三区| 久久精品视频一区| 蜜臀a∨国产成人精品| 777亚洲妇女| 午夜精品在线看| 欧美群妇大交群中文字幕| 亚洲午夜影视影院在线观看| 成人晚上爱看视频| 青青草国产精品97视觉盛宴| 91福利国产成人精品照片| 亚洲三级电影网站| 色8久久人人97超碰香蕉987| 一区二区在线观看免费视频播放| 一本大道久久精品懂色aⅴ| 欧美激情一区二区三区四区| 99vv1com这只有精品| 亚洲欧美激情插| 欧美一区二区三区视频免费播放| 奇米亚洲午夜久久精品| 日韩精品一区国产麻豆| 久久精品国产精品亚洲红杏| 欧美一区二区福利视频| 国产麻豆午夜三级精品| 中文字幕亚洲成人| 欧美日韩国产a| 国产伦精品一区二区三区免费| 国产精品嫩草影院com| 欧美探花视频资源| 蜜臀va亚洲va欧美va天堂| 国产欧美精品一区二区三区四区 | 久久亚区不卡日本| 成人精品gif动图一区| 亚洲大型综合色站| 亚洲国产精品v| 日韩一级成人av| 日本丶国产丶欧美色综合| 麻豆91在线播放| 一区二区三区四区乱视频| 久久久国产精华| 日韩视频一区二区在线观看| 在线观看不卡一区| 成人精品视频网站| 国产盗摄一区二区三区| 日韩av高清在线观看| 亚洲成人av一区二区三区| 国产精品美女久久久久久久久久久 | 欧美日韩激情在线| 91免费国产在线| 韩国av一区二区三区| 亚洲大型综合色站| 最新久久zyz资源站| 久久久久亚洲蜜桃| 日韩欧美精品三级| 欧美精品一区二区三区很污很色的| 欧美亚洲动漫制服丝袜| 欧美午夜一区二区三区免费大片| 成人黄色综合网站| 91黄色激情网站| 国产91丝袜在线播放| 成人福利视频在线| 色悠久久久久综合欧美99| 一本色道久久综合狠狠躁的推荐| 成人午夜视频在线| www.66久久| 色八戒一区二区三区| 884aa四虎影成人精品一区| 91精品国产综合久久精品图片| 欧美一级视频精品观看| 久久久久久久一区| 亚洲制服丝袜在线| 久久成人精品无人区| 国内精品伊人久久久久av影院| 国产高清视频一区| 欧美视频一区二区在线观看| 精品日韩av一区二区| 国产精品亲子伦对白| 亚洲国产精品尤物yw在线观看| 免费成人结看片| aaa亚洲精品一二三区| 日韩一级完整毛片| 国产精品嫩草影院av蜜臀| 天天爽夜夜爽夜夜爽精品视频| 麻豆专区一区二区三区四区五区| 成人免费视频国产在线观看| 8v天堂国产在线一区二区| 亚洲国产精品黑人久久久| 日韩国产精品久久久| 在线观看日韩电影| 久久99久久99精品免视看婷婷| 精品一区二区三区欧美| 欧美精品一二三四| 亚洲国产另类av| 97久久久精品综合88久久| 国产精品三级av在线播放| 国产一区二区不卡老阿姨| 欧美一级高清片| 日韩一区精品字幕| 91精品国产日韩91久久久久久| 亚洲国产综合91精品麻豆 | 日韩一卡二卡三卡四卡| 日韩精品成人一区二区在线| 337p亚洲精品色噜噜| 99久久精品国产一区二区三区| 国产偷国产偷精品高清尤物| 国产电影精品久久禁18| 欧美国产丝袜视频| 成人福利视频在线| 亚洲一区精品在线| 日韩欧美不卡在线观看视频| 韩国一区二区三区| 亚洲美女一区二区三区| 欧美高清dvd| 99视频精品在线| 日本色综合中文字幕| 亚洲国产高清不卡|