通过案例学调优之--Index FULL SCAN和Index FAST FULL SCAN
通过案例学调优之--IndexFULLSCAN和IndexFASTFULLSCANIndexFULLSCAN和ndexFASTFULLSCAN工作原理:IndexFULLSCAN和IndexFASTFULLSCAN的适用情况:适用于我们想选
INDEX FAST FULL SCAN:
HINT写法:INDEX_FFS(表名 索引名)
原理:从段头开始,读取包含位图块,ROOT BLOCK,所有的BRANCH BLOCK,LEAF BLOCK,读取的顺序完全有物理存储位置决定,并采取多块读,每次读取DB_FILE_MULTIBLOCK_READ_COUNT个块。查询某个表记录总数的时候,往往基于PRIMARY KEY的INDEX FAST FULL SCAN是最有效的。
Fast Full Index Scans :
Fast full index scans are an alternative to a full table scan when the index contains all the columns that are needed for the query, and at least one column in the index key has the NOT NULL constraint. A fast full scan accesses the data in the index itself, without accessing the table. It cannot be used to eliminate a sort operation, because the data is not ordered by the index key. It reads the entire index using multiblock reads, unlike a full index scan, and can be parallelized.
Fast full scan is available only with the CBO. You can specify it with the initialization parameter OPTIMIZER_FEATURES_ENABLE or the INDEX_FFS hint. Fast full index scans cannot be performed against bitmap indexes.
A fast full scan is faster than a normal full index scan in that it can use multiblock I/O and can be parallelized just like a table scan.
Full Table Scans :
This type of scan reads all rows from a table and filters out those that do not meet the selection criteria. During a full table scan, all blocks in the table that are under the high water mark are scanned. Each row is examined to determine whether it satisfies the statement’s WHERE clause.
When Oracle performs a full table scan, the blocks are read sequentially. Because the blocks are adjacent, I/O calls larger than a single block can be used to speed up the process. The size of the read calls range from one block to the number of blocks indicated by the initialization parameter DB_FILE_MULTIBLOCK_READ_COUNT. Using multiblock reads means a full table scan can be performed very efficiently. Each block is read only once.
案例分析:
1、创建表和索引
16:02:10 SYS@ prod >create table t as select * from dba_objects where 1=2; Table created. 16:05:43 SYS@ prod >insert into t select * from dba_objects where object_id is not null; 73025 rows created. 16:06:46 SYS@ prod >select count(*) from t; COUNT(*) ---------- 73025 16:06:56 SYS@ prod >commit; Commit complete. 16:13:48 SYS@ prod >exec dbms_stats.gather_table_stats('SYS','T',cascade=>true); PL/SQL procedure successfully completed. 16:14:33 SYS@ prod >set autotrace trace 16:15:32 SYS@ prod >select object_id from t; 73025 rows selected. Execution Plan ---------------------------------------------------------- Plan hash value: 1601196873 -------------------------------------------------------------------------- | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time | -------------------------------------------------------------------------- | 0 | SELECT STATEMENT | | 73025 | 356K| 284 (1)| 00:00:04 | | 1 | TABLE ACCESS FULL| T | 73025 | 356K| 284 (1)| 00:00:04 | -------------------------------------------------------------------------- Statistics ---------------------------------------------------------- 141 recursive calls 0 db block gets 5857 consistent gets 1038 physical reads 0 redo size 1060958 bytes sent via SQL*Net to client 53963 bytes received via SQL*Net from client 4870 SQL*Net roundtrips to/from client 4 sorts (memory) 0 sorts (disk) 73025 rows processed 从上面的执行计划中可知,此时走了全表扫描。 --由于我们需要查询的列为object_id,因此理论上只需要读取索引就应该可以返回所有数据,而此时为什么是全表扫描呢? --这是因为NULL值与索引的特性所决定的。即null值不会被存储到B树索引。因此应该为表 t 的列 object_id 添加 not null 约束。 16:16:14 SYS@ prod >desc t; Name Null? Type ----------------------------------------------------------------- -------- -------------------------------------------- OWNER VARCHAR2(30) OBJECT_NAME VARCHAR2(128) SUBOBJECT_NAME VARCHAR2(30) OBJECT_ID NUMBER DATA_OBJECT_ID NUMBER OBJECT_TYPE VARCHAR2(19) CREATED DATE LAST_DDL_TIME DATE TIMESTAMP VARCHAR2(19) STATUS VARCHAR2(7) TEMPORARY VARCHAR2(1) GENERATED VARCHAR2(1) SECONDARY VARCHAR2(1) NAMESPACE NUMBER EDITION_NAME VARCHAR2(30) 在object_id上添加not null约束 16:16:42 SYS@ prod >alter table t modify(object_id not null); Table altered. Elapsed: 00:00:00.34 16:16:46 SYS@ prod >desc t Name Null? Type ----------------------------------------------------------------- -------- -------------------------------------------- OWNER VARCHAR2(30) OBJECT_NAME VARCHAR2(128) SUBOBJECT_NAME VARCHAR2(30) OBJECT_ID NOT NULL NUMBER DATA_OBJECT_ID NUMBER OBJECT_TYPE VARCHAR2(19) CREATED DATE LAST_DDL_TIME DATE TIMESTAMP VARCHAR2(19) STATUS VARCHAR2(7) TEMPORARY VARCHAR2(1) GENERATED VARCHAR2(1) SECONDARY VARCHAR2(1) NAMESPACE NUMBER EDITION_NAME VARCHAR2(30)2、对Index_FS和Index_FFS对比

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











一般的な Web 標準とその実際の適用事例を理解する 今日のデジタル時代において、World Wide Web は人々が情報を取得し、通信し、ビジネス活動を行うための重要なプラットフォームとなっています。 Web 標準は、Web ページがさまざまなブラウザ上で正常に表示され、安定して動作することを保証するための基礎です。この記事では、いくつかの一般的な Web 標準を紹介し、実際の適用事例を通じてその重要性を説明します。まず、HTML (Hypertext Markup Language) は Web 標準の最も基本的な部分であり、Web ページの構造とコンテンツを記述するために使用されます。 HTML はタグを使用して次のことを定義します。

Go 言語では、標準入力「os.Stdin」からテキストを読み取る、つまりターミナルからデータを取得するために、Scan() メソッドが使用されます。このメソッドは、正常に読み取られたデータの数と発生したエラーを返します。読み取られたデータの数が指定されたパラメータよりも少ない場合は、エラー レポートの理由が返されます。

システム再インストール時に環境テストに失敗し、書き換えが必要になる場合の解決方法:携帯電話が汚染されているため、ウイルス対策として Mobile Manager などのウイルス対策ソフトをインストールしてください 2. ジャンクが多いファイルは携帯電話内に保存されるため、携帯電話の実行メモリが占有されます。この問題を解決するには、電話機のキャッシュをクリアするだけです。3. 保存されたソフトウェアやファイルによって電話機のメモリが占有されすぎています。不要なファイルやソフトウェアを頻繁に削除しても問題ありません。ハードウェア構成がインストール要件を満たしている限り、次のことが可能です。新しいものを直接使用してください。システム ディスクからシステムを再インストールしてください。 USB フラッシュ ドライブまたはハードディスクを使用してインストールでき、非常に高速です。ただし、重要なのは、互換性の良いシステム ディスク (IDE、ACHI、および RAID モードでのインストールをサポート) を使用することであり、自動的かつ永続的にアクティブ化できることが検証されています。それで

忙しい生産ラインでは、ロボットアームが効率的に連携し、オペレーターはリモートのリアルタイム制御を通じてプロセス全体を簡単に制御できます。鉱山では、技術専門家が AR メガネを着用し、メガネにリアルタイムで表示される情報を使用して、数千マイル離れた技術チームと協力して機器の問題を迅速に解決します。園内では無人配送車が自由に往復しており、家から出ずに荷物を受け取ることができる。これらのシナリオは架空のものではなく、クアルコムが最近リリースした「2023 Qualcomm Empowering Enterprise Digital Transformation Case Collection」に掲載されている実際のケースです。クアルコムは、主要な開発方向と実装のハイライトに焦点を当て、4 年連続で「モノのインターネット」をリリースしています。 「応用事例集」では、業界の最新技術の方向性と革新的な生態協力モデルを多面的かつ立体的に展示します。今年の事例集は、中国企業によるクアルコム テクノロジーの利用に焦点を当てています。

今日のインターネット時代では、オンラインで答えを見つけたり、質問についてコミュニケーションしたりすることを好む人がますます増えています。その結果、さまざまなオンライン質疑応答コミュニティが誕生しました。これらのコミュニティは、ユーザーが質問したり、質問に答えたり、経験や知識を互いに交換したりできるプラットフォームを提供します。今回は、PHPをベースに開発したオンラインQ&Aコミュニティの制作過程をご紹介します。まず、オンライン Q&A コミュニティにどのような機能が必要かを明確にする必要があります。一般的に、ユーザー登録、ログイン、質問、返信などの側面を含める必要があります。

人気のサーバーサイド プログラミング言語として、PHP は豊富なオブジェクト指向プログラミング機能を提供します。オブジェクト指向プログラミング (OOP) は、複雑なシステムを複数の個別のオブジェクトに分割することで開発とメンテナンスを簡素化するプログラミング手法です。この記事では、PHP でのオブジェクト指向プログラミングの事例を紹介し、簡単な例を通じて PHP でのオブジェクト指向プログラミングの応用を示します。 1. オブジェクト指向プログラミングの概念 PHP では、オブジェクト指向

PHP は、現代の Web サイト開発において非常に人気のあるバックエンド プログラミング言語です。時間が経つにつれて、ますます多くの PHP 関数ライブラリが開発され、開発者がより速くプログラムを作成し、コードの再利用性を向上できるようになりました。この記事では、開発者がこれらの関数ライブラリをより効果的に使用して開発効率を向上できるよう、実際的な PHP 関数ライブラリの事例をいくつか紹介します。 Alibaba Cloud OSSSDK Alibaba Cloud のオブジェクト ストレージ サービス (OSS) は、可用性と拡張性の高いクラウド ストレージ サービスです。開発者ができること

特定のコード例が必要な、Golang 汎用プログラミングの実践的なアプリケーション ケース はじめに: クラウド コンピューティング、ビッグ データ、人工知能の発展に伴い、ソフトウェア開発エンジニアは増大する課題に直面しています。プログラミング言語の汎用機能は、より効率的で柔軟なソリューションを提供できます。最新のプログラミング言語としての Golang は、バージョン 1.18 でついに汎用プログラミングのサポートを導入しました。この記事では、Golang 汎用プログラミングの実践的な応用例をいくつか紹介し、具体的なコード例を示します。コンテナの実装を簡素化する
