好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PostgreSQL 禁用全表掃描的實現

PostgreSQL 禁用全表掃描的實現

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

PostgreSQL可以通過一些設置來禁用全表掃描(FULL SCAN/Seq Scan)

注意:

設置此功能后不是完全避免全表掃描,而是只要有不通過全表掃描能得出結果的就不走全表掃描。

如果什么路都不通,那肯定得全表掃描,不然怎么獲取數據。

而且并不是不走全表掃描性能就一定好。

下面展示下這個功能:

查詢表結構:

highgo=# \d test
    Table test
 Column |    Type    | Modifiers 
-------------+--------------------------------+-----------
 G   | character varying(50)   | 
 A   | character varying(12)   | 
 M   | timestamp(0) without time zone | 
 W   | character varying(5)   | 
Indexes:
 "s__x0" btree ("G", "A", "M", "W")

先檢查視圖:

highgo=# select * from pg_db_role_setting ;
 setdatabase | setrole | setconfig 
-------------+---------+-----------
(0 rows)

查詢執行計劃:

highgo=# explain select "G","Z" from test where "G"='PG';
         QUERY PLAN         
------------------------------------------------------------------------------
 Seq Scan on test (cost=0.00..3.11 rows=1 width=72)
 Filter: (("G")::text = '7e'::text)
(2 rows)

對用戶進行限制:

highgo=# alter role xyh set enable_seqscan =off;
ALTER ROLE
 
highgo=# select * from pg_db_role_setting ;
 setdatabase | setrole |  setconfig  
-------------+---------+----------------------
   0 | 26171 | {enable_seqscan=off}

再次查詢執行計劃:

highgo=# explain select "G","Z" from test where "G"='7e';
         QUERY PLAN         
------------------------------------------------------------------------------
 Index Scan using "s__x0" on test (cost=0.14..8.15 rows=1 width=72)
 Index Cond: (("G")::text = '7e'::text)
(2 rows)

補充:psql 會引起全表掃描的10種sql語句

1、模糊查詢效率很低:

原因:like本身效率就比較低,應該盡量避免查詢條件使用like;對于like ‘%...%'(全模糊)這樣的條件,是無法使用索引的,全表掃描自然效率很低;另外,由于匹配算法的關系,模糊查詢的字段長度越大,模糊查詢效率越低。

解決辦法:首先盡量避免模糊查詢,如果因為業務需要一定要使用模糊查詢,則至少保證不要使用全模糊查詢,對于右模糊查詢,即like ‘…%',是會使用索引的;左模糊like

‘%...'無法直接使用索引,但可以利用reverse + function index 的形式,變化成 like ‘…%';全模糊是無法優化的,一定要的話考慮用搜索引擎。出于降低數據庫服務器的負載考慮,盡可能地減少數據庫模糊查詢。

2、查詢條件中含有is null的select語句執行慢

原因:Oracle 9i中,查詢字段is null時單索引失效,引起全表掃描。

解決方法:SQL語法中使用NULL會有很多麻煩,最好索引列都是NOT NULL的;對于is null,可以建立組合索引,nvl(字段,0),對表和索引analyse后,is null查詢時可以重新啟用索引查找,但是效率還不是值得肯定;is not null 時永遠不會使用索引。一般數據量大的表不要用is null查詢。

3、查詢條件中使用了不等于操作符(>、!=)的select語句執行慢

原因:SQL中,不等于操作符會限制索引,引起全表掃描,即使比較的字段上有索引

解決方法:通過把不等于操作符改成or,可以使用索引,避免全表掃描。例如,把column>'aaa',改成column'aaa' or column>'aaa',就可以使用索引了。

4、使用組合索引

如果查詢條件中沒有前導列,那么索引不起作用,會引起全表掃描;但是從Oracle9i開始,引入了索引跳躍式掃描的特性,可以允許優化器使用組合索引,即便索引的前導列沒有出現在WHERE子句中。

例如:

create index skip1 on emp5(job,empno); 

全索引掃描

select count(*) from emp5 where empno=7900; 

索引跳躍式掃描

select /*+ index(emp5 skip1)*/ count(*) from emp5 where empno=7900; 

前一種是全表掃描,后一種則會使用組合索引。

5、or語句使用不當會引起全表掃描

原因:where子句中比較的兩個條件,一個有索引,一個沒索引,使用or則會引起全表掃描。例如:where A=:1 or B=:2,A上有索引,B上沒索引,則比較B=:2時會重新開始全表掃描。

6、組合索引

排序時應按照組合索引中各列的順序進行排序,即使索引中只有一個列是要排序的,否則排序性能會比較差。

例如:

create index skip1 on emp5(job,empno,date); 
select job,empno from emp5 where job='manager'and empno='10' order by job,empno,date desc; 

實際上只是查詢出符合job='manager'and empno='10'條件的記錄并按date降序排列,但是寫成order by date desc性能較差。

7、Update 語句

如果只更改1、2個字段,不要Update全部字段,否則頻繁調用會引起明顯的性能消耗,同時帶來大量日志。

8、對于多張大數據量

(這里幾百條就算大了)的表JOIN,要先分頁再JOIN,否則邏輯讀會很高,性能很差。

9、select count(*) from table;

這樣不帶任何條件的count會引起全表掃描,并且沒有任何業務意義,是一定要杜絕的。

10、sql的where條件要綁定變量

比如where column=:1,不要寫成where column=‘aaa',這樣會導致每次執行時都會重新分析,浪費CPU和內存資源。

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

您可能感興趣的文章:
  • postgresql coalesce函數數據轉換方式
  • postgresql 中的COALESCE()函數使用小技巧
  • postgresql 實現修改jsonb字段中的某一個值
  • postgresql 實現將字段為空的值替換為指定值
  • 解決PostgreSQL Array使用中的一些小問題
  • postgresql 中的 like 查詢優化方案
  • sql 實現將空白值替換為其他值

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

巨人網絡通訊聲明:本文標題《PostgreSQL 禁用全表掃描的實現》,本文關鍵詞  PostgreSQL,禁用,全表,掃描,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL 禁用全表掃描的實現》相關的同類信息!
  • 本頁收集關于PostgreSQL 禁用全表掃描的實現的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 亚洲Va欧美va国产综合888| 亚洲AV乱码一区二区三区蜜桃| 国产精品久久久久无码软奇奇奇| 小仙女自慰www蹭蹭蹭av| 攻把受压在阳台上做| 爽爽国产色Av免费看| 1204金沙人妻懂旧版免费| 乱中年女人伦视频在线观看| 狼友美女丰满A级毛毛片| 国产精品理论片在线| 你别揉了我下面都出水了| 明星黄色小说| 强H被cao哭高H| 3d姉弟とイン动漫在线观看| 久久久这里只有精品加勒比| 无码成人性爽xo视频在线观看| 亚洲 国产 另类 无码 日韩| 亚洲性一级理论片在线观看| 校花小柔沦为全班的玩物| 中文字幕在线免费视频| 玉娟的性荡生活| 美女二区| 女性瘾者第三部无删减完整版| 成视频年人黄网站免费视频| 一级a免一级a做免费线看内裤| 床吻戏辣妞范1000免费| 午夜成年人| chinesegay老头8拾珍| MassageFreeSeX| 班长下面好紧好湿夹得好爽| 成人免费网站在线观看网址| 亚洲欧美一区二区三区九九九| 伊人久久大线蕉香港三级| 偷窥wc嘘嘘| 红桃精品??国产精品| 【免費A漫-禁漫天堂| bdsmtorture女囚夹乳| 纤夫的爱日本动漫观看下载| 暖暖免费观看日本版| 97人妻天天摸天天爽| 国产精品久久久久久久漫画软件|