校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識(shí)庫 > PostgreSQL數(shù)據(jù)庫中如何保證LIKE語句的效率(推薦)

PostgreSQL數(shù)據(jù)庫中如何保證LIKE語句的效率(推薦)

熱門標(biāo)簽:無錫梁溪公司怎樣申請(qǐng)400電話 孝感銷售電銷機(jī)器人廠家 智能電銷機(jī)器人教育 江西穩(wěn)定外呼系統(tǒng)供應(yīng)商 高德地圖標(biāo)注電話怎么沒了 中國地圖標(biāo)注省份用什么符號(hào) 北京智能外呼系統(tǒng)供應(yīng)商家 電話機(jī)器人錄音師薪資 奧維地圖標(biāo)注字體大小修改

在任何數(shù)據(jù)庫中使用LIKE語句往往都是令人頭疼的一件事,因?yàn)椴簧儆脩舭l(fā)現(xiàn)LIKE語句效率極低,查看執(zhí)行計(jì)劃后發(fā)現(xiàn)原來沒有走索引,那么在Postgresql數(shù)據(jù)中LIKE語句的執(zhí)行效率又是怎樣的呢?我們又該如何提高LIKE語句的執(zhí)行效率呢?

  實(shí)驗(yàn)環(huán)境

數(shù)據(jù)庫環(huán)境: PostgreSQL 12.3  X86_64  

創(chuàng)建虛擬環(huán)境:

postgres=# create database testdb01 owner highgo;
CREATE DATABASE
postgres=# \c testdb01 highgo
 
 
testdb01=# create table testliketb01 (userid int primary key,username varchar(20),password varchar(60),description text);
CREATE TABLE

為何保證測(cè)試效果更直觀,我們使用隨機(jī)數(shù)據(jù)填充一下該表

testdb01=# insert into testliketb01 select generate_series(1,500000),split_part('張三,李四,王五,小明,小紅',',',(random()*(5-1)+1)::int),md5((random()*(5-1)+1)::varchar),split_part('highgo,highgo02,highgo03',',',(random()*(3-1)+1)::int);

  至此,虛擬數(shù)據(jù)創(chuàng)建完畢。

testdb01=# select * from testliketb01 limit 10;
userid | username |             password             | description
--------+----------+----------------------------------+-------------
      1 | 王五     | 4f2bca371b42abd1403d5c20c4542dff | highgo
      2 | 李四     | 2a978c605188770c5ed162889fff189e | highgo02
      3 | 李四     | f5d129ab728b72ac6f663fe544bc7c16 | highgo
      4 | 小明     | 53134fa1022c58e65168b6aa1fbe5e39 | highgo02
      5 | 王五     | 2cf9abb2a8b676a626fa2c317d401ed8 | highgo02
      6 | 王五     | 2247a0cfda1f2819554d6e8e454622eb | highgo02
      7 | 張三     | 59dfdc680c17533dfba1c72c9ce0bf76 | highgo02
      8 | 王五     | 87db4258236a3826259dcc3e7cb5fc63 | highgo02
      9 | 王五     | baaf7a2f7027df9aaeb665121432b6e2 | highgo02
     10 | 王五     | 2f8fb36b3227c795b111b9bd5b031a76 | highgo02
(10 rows)
此時(shí)數(shù)據(jù)庫的狀態(tài):
testdb01=# \l+ testdb01
                                                List of databases
   Name   | Owner  | Encoding |   Collate   |    Ctype    | Access privileges | Size  | Tablespace | Description
----------+--------+----------+-------------+-------------+-------------------+-------+------------+-------------
testdb01 | highgo | UTF8     | en_US.UTF-8 | en_US.UTF-8 |                   | 59 MB | pg_default |
(1 row)

  簡單LIKE語句查詢:

testdb01=# explain analyze select * from testliketb01 where username like '王%';
                                                      QUERY PLAN                                                       
-----------------------------------------------------------------------------------------------------------------------
Seq Scan on testliketb01  (cost=0.00..11405.00 rows=125350 width=52) (actual time=0.014..177.571 rows=124952 loops=1)
   Filter: ((username)::text ~~ '王%'::text)
   Rows Removed by Filter: 375048
Planning Time: 0.121 ms
Execution Time: 190.554 ms
(5 rows)

結(jié)論:LIKE查詢沒有走索引   創(chuàng)建普通索引: testdb01=# create index idx_testliketb01_username on testliketb01(username); CREATE INDEX 執(zhí)行三遍:analyze testliketb01 ; 重新執(zhí)行LIKE語句,發(fā)現(xiàn)還是沒有走索引     創(chuàng)建包含operator class的索引: testdb01=# create index idx_testliketb01_username on testliketb01(username varchar_pattern_ops); CREATE INDEX 執(zhí)行三遍:analyze testliketb01 ;    

testdb01=# explain analyze select * from testliketb01 where username like '王%';
                                                                   QUERY PLAN                                                                    
-------------------------------------------------------------------------------------------------------------------------------------------------
Bitmap Heap Scan on testliketb01  (cost=2665.26..9387.14 rows=125350 width=52) (actual time=31.383..94.745 rows=124952 loops=1)
   Filter: ((username)::text ~~ '王%'::text)
   Heap Blocks: exact=5155
   ->  Bitmap Index Scan on idx_testliketb01_username  (cost=0.00..2633.92 rows=125350 width=0) (actual time=29.730..29.730 rows=124952 loops=1)
         Index Cond: (((username)::text ~>=~ '王'::text) AND ((username)::text ~~ '玌'::text))
Planning Time: 0.111 ms
Execution Time: 107.030 ms
(7 rows)

結(jié)論:在創(chuàng)建完普通索引并收集統(tǒng)計(jì)信息后數(shù)據(jù)庫在執(zhí)行LIKE語句時(shí)有可能仍然無法使用索引。在創(chuàng)建完帶有操作類的索引收集完統(tǒng)計(jì)信息后,執(zhí)行LIKE語句可以看到正常使用索引,且執(zhí)行效率有了不小提升。  

PS:operator class是Postgresql新版中創(chuàng)建索引的新選項(xiàng),旨在通過制定索引的操作類可以更精準(zhǔn)的收集統(tǒng)計(jì)信息。 

  為了更精準(zhǔn)的收集統(tǒng)計(jì)信息,我們也可以在初始化或者創(chuàng)建數(shù)據(jù)庫時(shí)將Collate設(shè)置為"C",這也是Postgresql數(shù)據(jù)中常用的優(yōu)化手段。   我們來測(cè)試一下將Collate設(shè)置為"C"的效果:

testdb01=# create database testdb02 with TEMPLATE template0  LC_COLLATE='C'  LC_CTYPE ='C' owner highgo;
CREATE DATABASE
 
 
testdb02=# \l+ testdb02
                                           List of databases
   Name   | Owner  | Encoding | Collate | Ctype | Access privileges | Size  | Tablespace | Description
----------+--------+----------+---------+-------+-------------------+-------+------------+-------------
testdb02 | highgo | UTF8     | C       | C     |                   | 59 MB | pg_default |
(1 row)
 
 
testdb02=# create index idx_testliketb01_username on testliketb01(username);
CREATE INDEX
testdb02=# analyze testliketb01 ;
ANALYZE
testdb02=# analyze testliketb01 ;
ANALYZE
testdb02=# analyze testliketb01 ;
ANALYZE
testdb02=#  explain analyze select * from testliketb01 where username like '王%';
                                                                   QUERY PLAN                                                                    
-------------------------------------------------------------------------------------------------------------------------------------------------
Bitmap Heap Scan on testliketb01  (cost=2680.26..9410.67 rows=126033 width=52) (actual time=35.262..99.052 rows=124992 loops=1)
   Filter: ((username)::text ~~ '王%'::text)
   Heap Blocks: exact=5155
   ->  Bitmap Index Scan on idx_testliketb01_username  (cost=0.00..2648.75 rows=126033 width=0) (actual time=33.920..33.920 rows=124992 loops=1)
         Index Cond: (((username)::text >= '王'::text) AND ((username)::text  '玌'::text))
Planning Time: 0.276 ms
Execution Time: 111.578 ms
(7 rows)

結(jié)論:創(chuàng)建數(shù)據(jù)庫時(shí)將Collate設(shè)置為"C",即便索引為普通索引,LIKE語句也可以使用索引提升查詢效率。    

優(yōu)化建議:

1、初始化數(shù)據(jù)庫或者創(chuàng)建數(shù)據(jù)庫時(shí)將Collate設(shè)置為"C"。

2、創(chuàng)建索引時(shí)指定索引的操作類。(text_pattern_ops、varchar_pattern_ops和 bpchar_pattern_ops分別支持類型text、varchar和 char上的B-tree索引)

3、優(yōu)化思路,對(duì)于%X的列無法使用索引,可以新增一列 反存儲(chǔ)列,將%X改為X%。

4、創(chuàng)建覆蓋索引,保證復(fù)雜SQL中可以盡可能調(diào)用該索引。

5、調(diào)整業(yè)務(wù)邏輯,盡量不用LIKE語句或者調(diào)整LIKE語句在WHERE中的位置。

到此這篇關(guān)于PostgreSQL數(shù)據(jù)庫中如何保證LIKE語句的效率的文章就介紹到這了,更多相關(guān)PostgreSQL保證LIKE語句的效率內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • postgresql 中的 like 查詢優(yōu)化方案
  • PostgreSQL regexp_matches替換like模糊查詢的操作
  • postgresql關(guān)于like%xxx%的優(yōu)化操作
  • PostgreSQL LIKE 大小寫實(shí)例
  • Postgresql中LIKE和ILIKE操作符的用法詳解

標(biāo)簽:海北 那曲 阜陽 通化 臨滄 泰州 齊齊哈爾 荊州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PostgreSQL數(shù)據(jù)庫中如何保證LIKE語句的效率(推薦)》,本文關(guān)鍵詞  PostgreSQL,數(shù)據(jù)庫,中,如何,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PostgreSQL數(shù)據(jù)庫中如何保證LIKE語句的效率(推薦)》相關(guān)的同類信息!
  • 本頁收集關(guān)于PostgreSQL數(shù)據(jù)庫中如何保證LIKE語句的效率(推薦)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    亚洲色欲色欲www| 99综合电影在线视频| 国产成人在线色| 欧美日韩精品一区视频| 久久精品人人做人人爽97| 日韩专区中文字幕一区二区| 风间由美一区二区av101| 欧美一区二区在线看| 亚洲免费资源在线播放| 国产·精品毛片| 日韩欧美亚洲国产精品字幕久久久| 国产精品欧美综合在线| 狂野欧美性猛交blacked| 欧美三级日韩在线| 亚洲精品久久7777| av男人天堂一区| 国产日韩视频一区二区三区| 久久精品理论片| 日韩一区二区不卡| 视频一区在线播放| 欧美日韩国产在线观看| 亚洲最新视频在线播放| www.激情成人| 国产精品午夜在线观看| 成人免费视频一区| 久久久精品人体av艺术| 久久国产精品露脸对白| 3d动漫精品啪啪一区二区竹菊| 亚洲综合一二三区| 欧美性做爰猛烈叫床潮| 亚洲免费在线播放| 在线视频中文字幕一区二区| 亚洲六月丁香色婷婷综合久久| av不卡免费在线观看| 国产精品美女久久久久久久| 成人国产精品免费网站| 国产精品不卡在线| 99视频一区二区三区| 中文字幕佐山爱一区二区免费| 成人福利视频在线看| 综合激情网...| 欧美视频精品在线| 日韩vs国产vs欧美| 欧美大片在线观看一区二区| 韩国在线一区二区| 久久九九国产精品| 91在线国产福利| 亚洲综合一区二区| 欧美岛国在线观看| 成人精品鲁一区一区二区| 自拍偷拍欧美精品| 7777精品伊人久久久大香线蕉的 | 国产亚洲成aⅴ人片在线观看| 经典一区二区三区| 国产精品丝袜久久久久久app| av成人免费在线观看| 午夜精品久久一牛影视| 欧美成va人片在线观看| 粉嫩嫩av羞羞动漫久久久| 亚洲免费av网站| 91精品国产91久久久久久一区二区 | 亚欧色一区w666天堂| 日韩欧美一区电影| 91影院在线免费观看| 天天综合日日夜夜精品| 国产欧美日韩另类一区| 在线视频你懂得一区| 久久精品国产一区二区三| 国产精品久久久久永久免费观看| 色综合天天综合网天天看片| 免费在线视频一区| 国产精品国产自产拍高清av王其| 欧美日韩国产a| 成人免费高清视频在线观看| 一区二区三区国产豹纹内裤在线| 欧美成人官网二区| 欧美伊人久久久久久午夜久久久久| 久久激情五月婷婷| 亚洲欧洲综合另类在线| 久久美女艺术照精彩视频福利播放| av成人免费在线观看| 国产在线精品不卡| 亚洲一区在线观看视频| 中文字幕免费在线观看视频一区| 欧美手机在线视频| 91在线观看高清| 国内外成人在线| 午夜久久久久久久久久一区二区| 国产精品女主播在线观看| 欧美一区二区视频在线观看| 91麻豆高清视频| 粉嫩蜜臀av国产精品网站| 久久se这里有精品| 免费一区二区视频| 亚洲第一搞黄网站| 亚洲精品国产无套在线观 | 在线播放一区二区三区| 99国产精品99久久久久久| 国产在线播放一区| 日韩国产精品大片| 亚洲韩国一区二区三区| 国产精品传媒视频| 中文字幕亚洲欧美在线不卡| 国产亚洲欧美日韩日本| 精品国产免费一区二区三区四区 | 欧美日韩在线播放三区| 成人毛片老司机大片| 国产一区二区三区免费| 水蜜桃久久夜色精品一区的特点| 亚洲色图视频网站| 亚洲视频一区二区免费在线观看| 中文字幕久久午夜不卡| 久久精品亚洲麻豆av一区二区| 2021久久国产精品不只是精品| 欧美成人精品二区三区99精品| 欧美一区二区三区日韩视频| 91精品免费在线观看| 91麻豆精品91久久久久久清纯| 在线成人免费视频| 日韩一区二区免费在线电影 | 日本高清不卡在线观看| 欧洲精品在线观看| 欧美唯美清纯偷拍| 欧美日韩亚洲丝袜制服| 欧美精品一卡二卡| 日韩视频123| 久久嫩草精品久久久久| 日本一区二区三区国色天香| 国产精品国产三级国产a| 最好看的中文字幕久久| 亚洲国产精品久久人人爱蜜臀| 亚洲美女区一区| 亚洲成人黄色小说| 久久99精品国产.久久久久久| 国内国产精品久久| 99视频国产精品| 欧美日韩在线综合| 久久在线免费观看| 亚洲丝袜制服诱惑| 亚洲va天堂va国产va久| 激情综合色丁香一区二区| 国产成人夜色高潮福利影视| 91麻豆免费视频| 日韩午夜精品电影| 国产精品毛片久久久久久久| 亚洲综合男人的天堂| 美女尤物国产一区| 高清国产午夜精品久久久久久| 色婷婷综合久久久中文字幕| 欧美精品在线一区二区| 国产欧美一区二区在线| 亚洲精品视频在线观看网站| 麻豆一区二区三| jvid福利写真一区二区三区| 欧美性受xxxx黑人xyx性爽| 日韩一级黄色大片| 国产精品每日更新| 麻豆91在线播放免费| 99久久国产综合精品色伊| 欧美成人伊人久久综合网| 国产精品久久久久久久久免费桃花 | 91在线无精精品入口| 精品日韩一区二区| 一级日本不卡的影视| 国产一区999| 91精品国产综合久久香蕉麻豆| 欧美高清在线视频| 麻豆一区二区99久久久久| 97se亚洲国产综合自在线不卡| 精品少妇一区二区三区| 亚洲国产一区视频| 91同城在线观看| 久久久久一区二区三区四区| 日韩黄色在线观看| 在线观看91精品国产入口| 国产精品无圣光一区二区| 韩日精品视频一区| 日韩美女视频在线| 在线综合+亚洲+欧美中文字幕| 精品欧美黑人一区二区三区| 国产精品福利av| 欧美亚一区二区| 狠狠色狠狠色合久久伊人| 国产欧美日韩另类视频免费观看| 日本在线观看不卡视频| 综合色中文字幕| 精品捆绑美女sm三区| 91欧美一区二区| 国产精品一区二区在线观看不卡 | 欧美二区乱c少妇| 国产.精品.日韩.另类.中文.在线.播放| 日本一区二区三区视频视频| 国产三级久久久| 成人美女在线视频| 亚洲激情一二三区| 欧美高清在线精品一区| 欧美成人艳星乳罩| 91 com成人网| 日韩一级完整毛片| 欧美丰满美乳xxx高潮www|