深入理解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

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Untuk menanyakan saiz ruang meja oracle, ikuti langkah -langkah berikut: Tentukan nama meja dengan menjalankan pertanyaan: pilih Tablespace_Name dari DBA_TableSpaces; Tanya saiz meja dengan menjalankan pertanyaan: pilih jumlah (bait) sebagai total_size, jumlah (bytes_free) sebagai tersedia_space, jumlah (bytes) - jumlah (bytes_free) sebagai digunakan_space dari dba_data_files di mana tablespace_

Penyulitan Oracle View membolehkan anda menyulitkan data dalam pandangan, dengan itu meningkatkan keselamatan maklumat sensitif. Langkah -langkah termasuk: 1) mewujudkan kunci penyulitan induk (MEK); 2) mencipta pandangan yang disulitkan, menyatakan pandangan dan MEK untuk disulitkan; 3) Memberi kuasa pengguna untuk mengakses pandangan yang disulitkan. Bagaimana pandangan yang disulitkan berfungsi: Apabila permintaan pengguna untuk paparan yang disulitkan, Oracle menggunakan MEK untuk menyahsulit data, memastikan bahawa hanya pengguna yang diberi kuasa dapat mengakses data yang boleh dibaca.

Mewujudkan Jadual Oracle melibatkan langkah -langkah berikut: Gunakan sintaks Create Table untuk menentukan nama jadual, nama lajur, jenis data, kekangan, dan nilai lalai. Nama jadual harus ringkas dan deskriptif, dan tidak boleh melebihi 30 aksara. Nama lajur hendaklah menjadi deskriptif, dan jenis data menentukan jenis data yang disimpan dalam lajur. Kekangan tidak null memastikan bahawa nilai null tidak dibenarkan dalam lajur, dan klausa lalai menentukan nilai lalai untuk lajur. Kekangan utama utama untuk mengenal pasti rekod unik jadual. Kekangan utama asing menentukan bahawa lajur dalam jadual merujuk kepada kunci utama dalam jadual lain. Lihat penciptaan pelajar jadual sampel, yang mengandungi kunci utama, kekangan unik, dan nilai lalai.

Kaedah Import Data: 1. Gunakan utiliti SQLLoader: Sediakan fail data, buat fail kawalan, dan jalankan SQLLoader; 2. Gunakan alat IMP/EXP: data eksport, data import. Petua: 1. Disyorkan SQL*loader untuk set data besar; 2. Jadual sasaran harus wujud dan perlawanan definisi lajur; 3. Selepas mengimport, integriti data perlu disahkan.

Nyahpasang Kaedah untuk kegagalan pemasangan Oracle: Tutup Perkhidmatan Oracle, Padam Fail Program Oracle dan Kekunci Pendaftaran, Nyahpasang pembolehubah persekitaran Oracle, dan mulakan semula komputer. Jika penyahpasang gagal, anda boleh menyahpasang secara manual menggunakan alat penyahpasang Oracle Universal.

Terdapat tiga cara untuk melihat nama contoh di Oracle: Gunakan "sqlplus" dan "pilih instance_name dari v $ instance;" Perintah pada baris arahan. Gunakan "pertunjukan instance_name;" Perintah dalam SQL*Plus. Semak Pembolehubah Alam Sekitar (ORACLE_SID pada Linux) melalui Pengurus Tugas Sistem Operasi, Pengurus Oracle Enterprise, atau melalui sistem operasi.

Terdapat kaedah berikut untuk mendapatkan masa di Oracle: Current_TimeStamp: Mengembalikan masa sistem semasa, tepat untuk beberapa saat. SystimeStamp: Lebih tepat daripada Current_TimeStamp, kepada nanodekonda. SYSDATE: Mengembalikan tarikh sistem semasa, tidak termasuk bahagian masa. To_char (sysdate, 'yyy-mm-dd hh24: mi: ss'): Menukar tarikh dan masa sistem semasa ke format tertentu. Ekstrak: Ekstrak bahagian tertentu dari nilai masa, seperti tahun, bulan, atau jam.

Laporan AWR adalah laporan yang memaparkan prestasi pangkalan data dan snapshot aktiviti. Langkah -langkah tafsiran termasuk: mengenal pasti tarikh dan masa snapshot aktiviti. Lihat gambaran keseluruhan aktiviti dan penggunaan sumber. Menganalisis aktiviti sesi untuk mencari jenis sesi, penggunaan sumber, dan acara menunggu. Cari kemunculan prestasi yang berpotensi seperti pernyataan SQL yang perlahan, perbalahan sumber, dan isu I/O. Lihat acara menunggu, mengenal pasti dan menyelesaikannya untuk prestasi. Menganalisis corak penggunaan selak dan memori untuk mengenal pasti isu memori yang menyebabkan masalah prestasi.
