老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

怎么在PostgreSQL數據庫中保證LIKE語句的效率-創新互聯

本篇文章給大家分享的是有關怎么在PostgreSQL數據庫中保證LIKE語句的效率,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

成都創新互聯專注為客戶提供全方位的互聯網綜合服務,包含不限于網站建設、成都網站建設、沙坡頭網絡推廣、重慶小程序開發、沙坡頭網絡營銷、沙坡頭企業策劃、沙坡頭品牌公關、搜索引擎seo、人物專訪、企業宣傳片、企業代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們大的嘉獎;成都創新互聯為所有大學生創業者提供沙坡頭建站搭建服務,24小時服務熱線:13518219792,官方網址:www.cdcxhl.com

 實驗環境


數據庫環境: 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語句的效率-創新互聯
轉載來于:http://www.xueling.net.cn/article/deidgo.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 不卡大片| 欧美国产精品久久久久久免费 | 青青草成人影视 | 欧美人与禽猛交乱配视频 | 久久只精品国产 | 成人看片黄A免费看在线 | 東热精品中字久久无码五月天 | 国产做a爱一级毛片久 | 精品久久久久久久妇女 | 久久久久国产精品人 | 国产免费不卡视频 | 欧洲av网 | 欧洲免费看片尺码大 | 国产探花一区二区 | 国产亚洲影视在线视频播放 | 999久久久无码国产精品 | 欧美美女性视频 | 91精品国产日韩91久久久久久 | 日本黄色大片视频 | 成年国产| 韩国女主播bj精品久久 | 桃花视频大全不卡免费观看网站 | 亚洲AV成人片色在线观看蜜桃 | www.av视频在线观看 | 好想被狂躁无码视频在线观看 | 国产精品污WWW在线观看 | 欧美成人做爰高潮片免费观看8850 | a免费毛片 | 国产精品色区 | 国产∨亚洲V天堂无码久久久 | 亚洲国产精品午夜伦不卡 | 少妇性色午夜淫片aaaze | 日韩一日| 国产高清乱理伦片中文 | 亚洲精品拍拍央视网出文 | 久草视频在线资源 | 免费欧洲毛片A级视频老妇女 | 美女四区 | 羞羞答答xxdd.tv | 91欧美一区二区三区 | 日本精品少妇一区二区三区 |