深入理解Oracle索引(18):函数索引的陷阱以及如何避免索引被污染
㈠ 函数索引的陷阱 使用函数索引一定要注意在函数代码变更后重建函数索引、否则、Oracle将返回错误结果但不给提示 测试如下: [plain] view plaincopyprint? SPANstyle=BACKGROUND-COLOR:rgb(102,102,102)hr@ORCLdroptabletpurge; Tabledropped. hr@ORCLcrea
㈠ 函数索引的陷阱使用函数索引一定要注意在函数代码变更后重建函数索引、否则、Oracle将返回错误结果但不给提示
测试如下:
[plain] view plaincopyprint?
- hr@ORCL> drop table t purge;
- Table dropped.
- hr@ORCL> create table t (x number,y varchar2(30));
- Table created.
- hr@ORCL> insert into t select rownum,rownum||'a' from dual connect by rownum
- 999 rows created.
- hr@ORCL> ed
- Wrote file afiedt.buf
- 1 create or replace function f_david(p_value varchar2) return varchar2
- 2 deterministic is
- 3 begin
- 4 return p_value;
- 5* end;
- 6
- 7 /
- Function created.
- hr@ORCL> create index idx_f_david_t on t (f_david(y));
- Index created.
- hr@ORCL> exec dbms_stats.gather_table_stats(ownname=>'HR',tabname=>'T',estimate_percent=>100,cascade=>TRUE,no_invalidate=>false);
- PL/SQL procedure successfully completed.
- hr@ORCL> select * from t where f_david(y)='8a';
- X Y
- ---------- ------------------------------
- 8 8a
- hr@ORCL> ed //ed是什么splplus命令?
- Wrote file afiedt.buf
- 1 create or replace function f_david(p_value varchar2) return varchar2
- 2 deterministic is
- 3 begin
- 4 return p_value||'b';
- 5* end;
- hr@ORCL> /
- Function created.
- /* 此时的函数 f_david 已经不是我们所认识的那个了、但是查询依然如故!!!*/
- hr@ORCL> select * from t where f_david(y)='8a';
- X Y
- ---------- ------------------------------
- 8 8a
- /* 索引重建查询没有记录、这才是我们要的正确结果*/
- hr@ORCL> drop index idx_f_david_t;
- Index dropped.
- hr@ORCL> create index idx_f_david_t on t (f_david(y));
- Index created.
- hr@ORCL> exec dbms_stats.gather_table_stats(ownname=>'HR',tabname=>'T',estimate_percent=>100,cascade=>TRUE,no_invalidate=>false);
- PL/SQL procedure successfully completed.
- hr@ORCL> select * from t where f_david(y)='8a';
- no rows selected
<span>hr@ORCL> drop table t purge; Table dropped. hr@ORCL> create table t (x number,y varchar2(30)); Table created. hr@ORCL> insert into t select rownum,rownum||'a' from dual connect by rownum ed Wrote file afiedt.buf 1 create or replace function f_david(p_value varchar2) return varchar2 2 deterministic is 3 begin 4 return p_value; 5* end; 6 7 / Function created. hr@ORCL> create index idx_f_david_t on t (f_david(y)); Index created. hr@ORCL> <span><span><strong>exec dbms_stats.gather_table_stats(ownname=>'HR',tabname=>'T',estimate_percent=>100,cascade=>TRUE,no_invalidate=>false); //这句话什么意思?</strong> </span> </span>PL/SQL procedure successfully completed. hr@ORCL> select * from t where f_david(y)='8a'; X Y ---------- ------------------------------ 8 8a hr@ORCL> ed Wrote file afiedt.buf 1 create or replace function f_david(p_value varchar2) return varchar2 2 deterministic is 3 begin 4 return p_value||'b'; 5* end; hr@ORCL> / Function created. /* 此时的函数 f_david 已经不是我们所认识的那个了、但是查询依然如故!!!*/ hr@ORCL> select * from t where f_david(y)='8a'; X Y ---------- ------------------------------ 8 8a /* 索引重建查询没有记录、这才是我们要的正确结果*/ hr@ORCL> drop index idx_f_david_t; Index dropped. hr@ORCL> create index idx_f_david_t on t (f_david(y)); Index created. hr@ORCL> exec dbms_stats.gather_table_stats(ownname=>'HR',tabname=>'T',estimate_percent=>100,cascade=>TRUE,no_invalidate=>false); PL/SQL procedure successfully completed. hr@ORCL> select * from t where f_david(y)='8a'; no rows selected</span>
㈡ 避免索引被污染
这里给出 2 条意见、
① 不要在字段前增加函数
如:
to_char(start_time,'yyyy.mm.dd') between '2013.06.06' and '2013.06.10'
和
start_time between to_date('2013.06.06','yyyy.mm.dd') and to_date('2013.06.10','yyyy.mm.dd')
任何时候都应该是第二种!!!
② 不要把字段嵌入到表达式中
如:
start_time + 7
和
start_time
By David Lin
2013-06-06
Good Luck

ホット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)

ホットトピック









Oracle Tablespaceサイズを照会するには、次の手順に従ってください。クエリを実行して、TableSpace名を決定します。DBA_TABLESPACesからTableSpace_Nameを選択します。クエリを実行してテーブルスペースのサイズをクエリします:sum(bytes)をtotal_size、sum(bytes_free)asavail_space、sum(bytes) - sum(bytes_free)as sum(bytes_free)as dba_data_files from tablespace_

Oracle View暗号化により、ビュー内のデータを暗号化でき、それにより機密情報のセキュリティが強化されます。手順には以下が含まれます。1)マスター暗号化キー(MEK)の作成。 2)暗号化されたビューを作成し、暗号化されるビューとMEKを指定します。 3)暗号化されたビューにアクセスすることをユーザーに許可します。暗号化されたビューがどのように機能するか:ユーザーが暗号化されたビューを求めてクエリをするとき、OracleはMEKを使用してデータを復号化し、認定ユーザーのみが読み取り可能なデータにアクセスできるようにします。

Oracleテーブルの作成には、次の手順が含まれます。作成テーブルの構文を使用して、テーブル名、列名、データ型、制約、およびデフォルト値を指定します。テーブル名は簡潔で説明的である必要があり、30文字を超えてはなりません。列名は説明的でなければならず、データ型は列に保存されているデータ型を指定します。 NOT NULL制約により、列でnull値が許可されていないことが保証され、デフォルト句は列のデフォルト値を指定します。テーブルの一意の記録を識別する主要なキーの制約。外部キーの制約は、表の列が別のテーブルの主キーを指していることを指定します。主要なキー、一意の制約、デフォルト値を含むサンプルテーブル学生の作成を参照してください。

データインポート方法:1。SQLLOADERユーティリティを使用します。データファイルを準備し、制御ファイルを作成し、SQLLoaderを実行します。 2。IMP/EXPツールを使用します。データをエクスポートし、データをインポートします。ヒント:1。ビッグデータセットに推奨されるSQL*ローダー。 2。ターゲットテーブルが存在する必要があり、列定義が一致します。 3。インポート後、データの整合性を検証する必要があります。

Oracleインストール障害のためのアンインストールメソッド:Oracleサービスを閉じ、Oracleプログラムファイルとレジストリキーを削除し、Oracle環境変数をアンインストールし、コンピューターを再起動します。アンインストールが失敗した場合、Oracle Universal Uninstallツールを使用して手動でアンインストールできます。

Oracleでインスタンス名を表示するには3つの方法があります。「sqlplus」と「v $ instanceからselect instance_name;」を使用します。」コマンドラインのコマンド。 「show instance_name;」を使用しますSQL*Plusのコマンド。オペレーティングシステムのタスクマネージャー、Oracle Enterprise Manager、またはオペレーティングシステムを介して、環境変数(LinuxのOracle_Sid)を確認してください。

Oracleで時間を取得するには、次の方法があります。Current_Timestamp:現在のシステム時間を秒に正確に返します。 systimestamp:current_timestampよりも正確で、ナノ秒。 sysdate:時間部分を除く現在のシステム日付を返します。 to_char(sysdate、 'yyy-mm-dd hh24:mi:ss'):現在のシステムの日付と時刻を特定の形式に変換します。抽出:1年、月、時間など、時間の値から特定の部分を抽出します。

AWRレポートは、データベースのパフォーマンスとアクティビティスナップショットを表示するレポートです。解釈の手順には、アクティビティスナップショットの日付と時刻の識別が含まれます。アクティビティとリソース消費の概要をご覧ください。セッションのアクティビティを分析して、セッションの種類、リソース消費、待機イベントを見つけます。遅いSQLステートメント、リソース競合、I/Oの問題などの潜在的なパフォーマンスボトルネックを見つけます。待機イベントを表示し、パフォーマンスのためにそれらを特定して解決します。ラッチとメモリの使用パターンを分析して、パフォーマンスの問題を引き起こしているメモリの問題を特定します。
