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

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

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

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

在任何數據庫中使用LIKE語句往往都是令人頭疼的一件事,因為不少用戶發現LIKE語句效率極低,查看執行計劃后發現原來沒有走索引,那么在Postgresql數據中LIKE語句的執行效率又是怎樣的呢?我們又該如何提高LIKE語句的執行效率呢?

  實驗環境

數據庫環境: PostgreSQL 12.3  X86_64  

創建虛擬環境:

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

為何保證測試效果更直觀,我們使用隨機數據填充一下該表

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);

  至此,虛擬數據創建完畢。

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)
此時數據庫的狀態:
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)

結論:LIKE查詢沒有走索引   創建普通索引: testdb01=# create index idx_testliketb01_username on testliketb01(username); CREATE INDEX 執行三遍:analyze testliketb01 ; 重新執行LIKE語句,發現還是沒有走索引     創建包含operator class的索引: testdb01=# create index idx_testliketb01_username on testliketb01(username varchar_pattern_ops); CREATE INDEX 執行三遍: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)

結論:在創建完普通索引并收集統計信息后數據庫在執行LIKE語句時有可能仍然無法使用索引。在創建完帶有操作類的索引收集完統計信息后,執行LIKE語句可以看到正常使用索引,且執行效率有了不小提升。  

PS:operator class是Postgresql新版中創建索引的新選項,旨在通過制定索引的操作類可以更精準的收集統計信息。 

  為了更精準的收集統計信息,我們也可以在初始化或者創建數據庫時將Collate設置為"C",這也是Postgresql數據中常用的優化手段。   我們來測試一下將Collate設置為"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)

結論:創建數據庫時將Collate設置為"C",即便索引為普通索引,LIKE語句也可以使用索引提升查詢效率。    

優化建議:

1、初始化數據庫或者創建數據庫時將Collate設置為"C"。

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

3、優化思路,對于%X的列無法使用索引,可以新增一列 反存儲列,將%X改為X%。

4、創建覆蓋索引,保證復雜SQL中可以盡可能調用該索引。

5、調整業務邏輯,盡量不用LIKE語句或者調整LIKE語句在WHERE中的位置。

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

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

標簽:海北 那曲 阜陽 通化 臨滄 泰州 齊齊哈爾 荊州

巨人網絡通訊聲明:本文標題《PostgreSQL數據庫中如何保證LIKE語句的效率(推薦)》,本文關鍵詞  PostgreSQL,數據庫,中,如何,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL數據庫中如何保證LIKE語句的效率(推薦)》相關的同類信息!
  • 本頁收集關于PostgreSQL數據庫中如何保證LIKE語句的效率(推薦)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产在线精品视频| 成人网在线免费视频| 午夜在线成人av| 精品一区二区成人精品| 一区二区成人在线视频| 美腿丝袜亚洲综合| 欧美经典一区二区| 欧美三级日韩三级| 久久亚洲综合色一区二区三区| 美国精品在线观看| 日本不卡一二三区黄网| 中文字幕欧美区| 成人一级片网址| 亚洲精品大片www| 色网综合在线观看| 亚洲成av人**亚洲成av**| 欧美一区二区精美| 国产白丝网站精品污在线入口| 亚洲伦在线观看| 欧美精品一区二区三区一线天视频| 成人中文字幕电影| 亚洲三级在线免费| 欧美系列一区二区| 中文字幕一区二区不卡| 韩国午夜理伦三级不卡影院| 日韩一级片在线观看| 国产午夜精品理论片a级大结局 | 欧美日韩久久一区| 91精品欧美福利在线观看| 蜜臀久久99精品久久久画质超高清 | 99国产精品久| 美女性感视频久久| 亚洲最新视频在线播放| 国产日产精品一区| 欧美精选午夜久久久乱码6080| 国产风韵犹存在线视精品| 亚洲国产欧美日韩另类综合| 日本一区二区电影| www亚洲一区| 日韩欧美综合一区| 欧美日韩精品是欧美日韩精品| 国产一区二区在线影院| 亚洲成av人片www| 亚洲三级免费电影| 国产精品美女久久久久aⅴ | 亚洲美女偷拍久久| 欧美精品一区二区三区在线播放| 欧美精品一二三区| 欧美三级电影一区| 欧美日韩一区二区三区在线| 欧美亚日韩国产aⅴ精品中极品| 丁香另类激情小说| 色婷婷狠狠综合| 成人午夜视频在线观看| 国产·精品毛片| 国产在线日韩欧美| 美脚の诱脚舐め脚责91| 麻豆专区一区二区三区四区五区| 日韩不卡一区二区| 奇米一区二区三区| 国产综合久久久久影院| 精品一区二区三区在线观看 | 亚洲国产美女搞黄色| 亚洲欧美精品午睡沙发| 亚洲日本va午夜在线电影| 国产精品久久免费看| 亚洲欧洲av另类| 亚洲免费观看高清完整版在线| 综合久久国产九一剧情麻豆| 亚洲欧美视频在线观看视频| 一区二区三区在线视频观看58| 亚洲观看高清完整版在线观看| 五月天一区二区三区| 日本va欧美va精品| 免费人成在线不卡| 加勒比av一区二区| www.亚洲国产| 91成人免费电影| 欧美一区二区免费观在线| 日韩欧美在线1卡| 久久精品人人做人人综合| 国产色91在线| 亚洲精品一二三| 日本在线不卡一区| 国产精品1区2区3区| 99re成人在线| 欧美日韩国产综合一区二区三区| 日韩欧美卡一卡二| 中文字幕一区二区三区不卡在线 | 亚洲欧美日韩中文字幕一区二区三区| 亚洲视频一二区| 麻豆精品精品国产自在97香蕉| 国产真实乱对白精彩久久| 91麻豆成人久久精品二区三区| 欧美日韩五月天| 久久久久九九视频| 亚洲一区二区三区中文字幕在线| 青青国产91久久久久久| 成人h版在线观看| 日韩一区二区三区三四区视频在线观看 | 国产一区二区三区在线看麻豆| 97精品久久久久中文字幕| 欧美日韩国产系列| 欧美高清在线一区| 免费高清在线一区| 在线观看一区日韩| 日本一二三四高清不卡| 日本成人超碰在线观看| 99re这里只有精品6| 国产一区二区精品久久91| 在线不卡一区二区| 97久久精品人人做人人爽50路| 日韩一区二区三区免费看| 日韩电影免费在线观看网站| 欧美精品欧美精品系列| 三级影片在线观看欧美日韩一区二区| 欧美日韩另类国产亚洲欧美一级| 美女一区二区三区在线观看| 久久精品人人做人人爽97| 成人av免费在线观看| 伊人色综合久久天天| 日韩三级视频在线看| 国产麻豆精品一区二区| 性久久久久久久久久久久| 色综合久久99| 日韩电影网1区2区| 欧美在线色视频| 另类欧美日韩国产在线| 欧美精品一区二区三区视频| 日韩理论片中文av| 欧美日韩在线观看一区二区| 国产一区二区三区在线观看免费视频 | 国产精品乱码妇女bbbb| 2022国产精品视频| 男男视频亚洲欧美| 精品视频资源站| 亚洲与欧洲av电影| 色综合久久99| 国产精品国模大尺度视频| 国产成人啪免费观看软件| 精品国产欧美一区二区| 精品一区二区在线视频| 欧美人xxxx| 奇米色777欧美一区二区| 欧美日韩久久一区| 亚洲高清视频在线| 777a∨成人精品桃花网| 日韩电影一二三区| 日韩视频123| 国产成人午夜视频| 国产精品大尺度| 欧美制服丝袜第一页| 香港成人在线视频| 日韩一卡二卡三卡四卡| 国产一区二三区| 综合在线观看色| 欧美日韩精品是欧美日韩精品| 毛片基地黄久久久久久天堂| 久久久精品tv| 一道本成人在线| 亚洲一区二区精品视频| 宅男噜噜噜66一区二区66| 秋霞av亚洲一区二区三| 国产欧美精品区一区二区三区| 91美女视频网站| 麻豆久久久久久| 欧美激情一区二区三区在线| 99精品桃花视频在线观看| 亚洲小说春色综合另类电影| 日韩午夜小视频| 福利电影一区二区| 亚洲激情欧美激情| 欧美v日韩v国产v| 一本一道波多野结衣一区二区| 日产国产欧美视频一区精品| 国产精品色哟哟网站| 欧美剧在线免费观看网站| 国产精品99久| 婷婷中文字幕一区三区| 国产偷国产偷亚洲高清人白洁| 欧美在线短视频| 成人黄色电影在线| 无码av免费一区二区三区试看| 久久久亚洲高清| 在线不卡的av| 色老汉av一区二区三区| 国产一区亚洲一区| 午夜精品福利一区二区蜜股av| 国产日韩v精品一区二区| 欧美日韩激情在线| 色激情天天射综合网| 国产91在线|亚洲| 国产综合色产在线精品| 肉色丝袜一区二区| 97精品国产露脸对白| **欧美大码日韩| 久久久久久免费网| 欧美熟乱第一页| 成人理论电影网| 日日欢夜夜爽一区|