Rumah pangkalan data tutorial mysql Stored Outline存储提纲介绍

Stored Outline存储提纲介绍

Jun 07, 2016 pm 03:22 PM
out outline memperkenalkan penyimpanan

第一篇:outline是什么? outline设计来提供稳定的执行计划,以消除执行环境或对象统计信息的改变造成的影响。这个特性叫做计划稳定性。其实outline就是一堆hint的集合。 查询优化器接收到sql后,在选择是否使用OUTLINE时的逻辑。 a.对SQL语句进行标准化去除

第一篇:outline是什么? outline设计来提供稳定的执行计划,以消除执行环境或对象统计信息的改变造成的影响。这个特性叫做计划稳定性。其实outline就是一堆hint的集合。 查询优化器接收到sql后,在选择是否使用OUTLINE时的逻辑。 a.对SQL语句进行标准化去除空白大小写差异 b.计算签名 c.对比数据字典,看是否已存在一样的签名 d.如果是,再进一步比较sql语句是否相同(避免hash冲突) e.如果SQL一样,就可以将这个outline的相关hint收入郎中,以影响执行计划的生成了。
9i开始就可以用outline,但10g开始才可以从共享池的一个游标来手动创建outline。 要使用use_stored_outlines,必须开启use_stored_outlines参数 alter system set use_stored_outlines = test; 当一条SQL语句有sql profile又有outline时,查询优化器会有限选择outline。 何时使用: 每当调优一条特殊的SQL并且无法在应用程序里修改它时(比如,不能使用hint),就可以使用这项技术。但如果加了hint也不走一些执行计划,那用outline也木有用。 比如id列是varchar2(1)并且有索引,而sql用where to_number(id)=1,此时加了/*+index(t ind)*/也不走索引,用outline也无补于事。
第二篇:创建outline
1.自创创建outline ALTER [SESSION | SYSTEM] SET create_stored_outlines=TRUE|类别名; 例子:alter session set create_stored_outlines=fwy; --true模式的category是default 这个参数无法在参数文件指定,只能起库后再人工或触发器指定。

2.手动创建outline 2.1 基于文本 create or replace outline out_1 --for category test on select 3+8 from dual;
2.2.基于hash_value begin dbms_outln.create_outline( hash_value=>'1812086974', child_number =>0 -- category => 'test' ); end; /
第三篇:查询outline select * from dba_outlines where timestamp>sysdate-1/24;--过去一小时刚建的outline select * from dba_outlines where timestamp>sysdate-5/(24*60); --过去5分钟建的outline select hint from dba_outline_hints where name='OUTLINE_FROM_TEXT';--查询某个outline的hint集合
查看outline是否有被使用 1. 10gR2起,dbms_xplan函数看执行计划,会看到是否有使用Outline 2. 所有版本通行: execute dbms_outln.clear_used(name=> 'OUT_1'); --重置outline使用标记 select used from dba_outlines where name='OUT_1';--显示UNUSED 然后执行SQL select used from dba_outlines where name='OUT_1';--此时如果显示为used,则上述SQL有用到该OUTLINE了。

第四篇:更改OUTLINE --Rename outline alter outline SYS_OUTLINE_13090110433120101 rename to out2;
--更改单个outline的类别 alter outline out2 change category to default;
--更改多个outline类别,属于类别TEST的整体替换为类别default execute dbms_outln.update_by_cat(oldcat=>'TEST',newcat=>'DEFAULT');
--重建存储提纲 当你希望query optimizer根据新环境产生一个新的hint集合,可以使用它。比如改变了outline相关对象的访问结构时。 alter outline out_1 rebuild;
--query optimizer只考虑激活的outline,outline有两个条件符合才可以被激活 --第一,要处于enable状态。 创建时默认就是。如果不是可以通过以下语句做状态变换。 alter outline out_1 enable; alter outline out_1 disable; --第二,初始化参数use_stored_outlines在session级别或system级别激活。 true就是用default类别,false就是不用outline,或者某个类别名。 alter session set use_stored_outlines=true; alter system set use_stored_outlines=true; --这个参数一次只能激活一个类别,也就是跟sql profile一样,一个会话一次只能用一个类别。 十分奇怪的是,这个参数无法在pfile或者spfile中设置,只能实例系统后再设置。也可以借助触发器完成。

第五篇:移动outline --------------------------------------- vi exp.par userid="/ as sysdba" file=exp01.dmp log=exp_outline.log tables=(outln.ol$,outln.ol$hints,outln.ol$nodes) query="where ol_name ='FWY_3'" ---------------------------------------------------- exp parfile=exp.par ------------------------------vi imp.par userid="/ as sysdba" file=exp01.dmp log=imp_outline.log full=y ignore=y -----------------------------imp parfile=imp.par
--移动单个outline或者单个类别,在上述基础上加上以下语句 query="where ol_name ='OUT_1'" query="where category='TEST'" 比如,如果一个给定的 SQL语句的执行计划使用了一个你本想避免的索引扫描,那么你可以在测试系统中删除索引,在那里生成一个Outline,然后再将其转移到生产环境。
第六篇:编辑outline 想要编辑outline里面的hint,对数据字典中的公有outline用一些普通的SQL进行update是不行的,而对私有outline进行编辑是可行的。私有outline是存储在工作表中的,经过创建、编辑、测试后,我们可以将私有outline发布成公有outline。
1创建的两种方法 1.1. create or replace private outline out_3 on select * from dual; 1.2 create private outline p_out_1 from public out_1;
--10g后,默认工作表就是在system用户下的ol$,ol$hints,ol$nodes,还有默认的三个公共同义词指向它们。对于这三个表,在outln中也是有的,这才是作为公有的outline而存在的表。 如果用9i,就要手动创建工作表与公共同义词。 sqlplus '/as sysdba' alter session set current_schema=system; execute dbms_outln_edit.create_edit_tables;
create or replace public synonym ol$ for system.ol$;
create or replace public synonym ol$hints for system.ol$hints; create or replace public synonym ol$nodes for system. ol$nodes ;
grant select,insert,update,delete on system.ol$ to public; grant select,insert,update,delete on system.ol$hints to public; grant select,insert,update,delete on system.ol$nodes to public;
一旦私有outline创建完毕,就可以列出私有outline相关的Hint select hint#,hint_text from system.ol$hints where ol_name='OUT_4';
--然后用普通的sql语句可以更新它的hint --本来HINT#的1的hint_text是 INDEX(@"SEL$1" "T"@"SEL$1" ("T"."N")) --现在要变成走全表扫描 update ol$hints set hint_text='FULL(@SEL$1 T)' where hint#=1 and ol_name='P_OUTLINE_EDITING'; --为了确保这个outline在内存中的副本也同步进行了更改,执行如下 execute dbms_outln_edit.refresh_private_outline('OUT_1') --接着,激活并测试这个private outline. alter session set use_private_outlines =true; explain plan for select * from t where n=1970; select * from table(dbms_xplan.display(null,null,'basic +note)')); --如果对private outline满意,就可以使用下面这个sql将它发布成public outline. create public outline out_1 from private p_out_1;
第七篇 删除存储提纲 删除单个 drop outline out_1; 删除整类别 dbms_outln.drop_by_cat(cat=>'TEST'); 删除私有提纲 drop private outline out_1;
第八篇:OUTLINE互换 --将BEFORE与AFTER两个outline互换 UPDATE OUTLN.OL$HINTS SET OL_NAME=DECODE(OL_NAME,'AFTER','BEFORE','BEFORE','AFTER') WHERE OL_NAME IN ('AFTER','BEFORE');

 

exec dbms_outln.update_signatures; --更新签名

drop outline after;--更换完后,可以将不用的outline删除

 

第九篇:其他事项 在10gr1之前,outline是不能覆盖初始化参数,为了成功用outline,这几个初始化参数要与执行化境设置保持一致才可以噢。 optimizer_features_enable query_rewrite_enabled star_transformation_enabled
A用户创建的outline,B用户也可以用,不用授权。 OUTLINE在RAC环境下,每个实例都需要开启使用参数,才能用OUTLINE。

 

 


Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Pengenalan terperinci tentang apa itu wapi Pengenalan terperinci tentang apa itu wapi Jan 07, 2024 pm 09:14 PM

Pengguna mungkin pernah melihat istilah wapi apabila menggunakan Internet, tetapi bagi sesetengah orang mereka pasti tidak tahu apa itu wapi Berikut adalah pengenalan terperinci untuk membantu mereka yang tidak tahu untuk memahami. Apa itu wapi: Jawapan: wapi ialah infrastruktur untuk pengesahan dan kerahsiaan LAN wayarles. Ini seperti fungsi seperti inframerah dan Bluetooth, yang biasanya dilindungi berhampiran tempat seperti bangunan pejabat. Pada asasnya mereka dimiliki oleh jabatan kecil, jadi skop fungsi ini hanya beberapa kilometer. Pengenalan berkaitan wapi: 1. Wapi ialah protokol penghantaran dalam LAN wayarles. 2. Teknologi ini dapat mengelakkan masalah komunikasi jalur sempit dan membolehkan komunikasi yang lebih baik. 3. Hanya satu kod diperlukan untuk menghantar isyarat

Penjelasan terperinci sama ada win11 boleh menjalankan permainan PUBG Penjelasan terperinci sama ada win11 boleh menjalankan permainan PUBG Jan 06, 2024 pm 07:17 PM

Pubg, juga dikenali sebagai PlayerUnknown's Battlegrounds, ialah permainan shooting battle royale yang sangat klasik yang telah menarik ramai pemain sejak popularitinya pada 2016. Selepas pelancaran sistem win11 baru-baru ini, ramai pemain ingin memainkannya di win11 Jom ikuti editor untuk melihat sama ada win11 boleh bermain pubg. Bolehkah win11 bermain pubg? 1. Pada permulaan win11, kerana win11 perlu untuk membolehkan tpm, ramai pemain telah diharamkan dari pubg. 2. Walau bagaimanapun, berdasarkan maklum balas pemain, Blue Hole telah menyelesaikan masalah ini, dan kini anda boleh bermain pubg seperti biasa dalam win11. 3. Kalau jumpa pub

Huawei akan melancarkan produk storan MED yang inovatif tahun depan: kapasiti rak melebihi 10 PB dan penggunaan kuasa kurang daripada 2 kW Huawei akan melancarkan produk storan MED yang inovatif tahun depan: kapasiti rak melebihi 10 PB dan penggunaan kuasa kurang daripada 2 kW Mar 07, 2024 pm 10:43 PM

Laman web ini melaporkan pada 7 Mac bahawa Dr. Zhou Yuefeng, Presiden Barisan Produk Penyimpanan Data Huawei, baru-baru ini menghadiri persidangan MWC2024 dan secara khusus menunjukkan penyelesaian penyimpanan magnetoelektrik OceanStorArctic generasi baharu yang direka untuk data hangat (WarmData) dan data sejuk (ColdData). Zhou Yuefeng, Presiden barisan produk penyimpanan data Huawei, mengeluarkan satu siri penyelesaian inovatif Sumber imej: Siaran akhbar rasmi Huawei yang dilampirkan pada tapak ini adalah seperti berikut: Kos penyelesaian ini adalah 20% lebih rendah daripada pita magnetik. penggunaan kuasa adalah 90% lebih rendah daripada cakera keras. Menurut bloksandfiles media teknologi asing, jurucakap Huawei turut mendedahkan maklumat tentang penyelesaian storan magnetoelektrik: Cakera magnetoelektronik (MED) Huawei ialah inovasi utama dalam media storan magnetik. Generasi pertama ME

Pengenalan kepada fungsi Python: Pengenalan dan contoh fungsi exec Pengenalan kepada fungsi Python: Pengenalan dan contoh fungsi exec Nov 03, 2023 pm 02:09 PM

Pengenalan kepada fungsi Python: Pengenalan dan contoh fungsi exec Pengenalan: Dalam Python, exec ialah fungsi terbina dalam yang digunakan untuk melaksanakan kod Python yang disimpan dalam rentetan atau fail. Fungsi exec menyediakan cara untuk melaksanakan kod secara dinamik, membolehkan program menjana, mengubah suai dan melaksanakan kod seperti yang diperlukan semasa masa jalan. Artikel ini akan memperkenalkan cara menggunakan fungsi exec dan memberikan beberapa contoh kod praktikal. Cara menggunakan fungsi exec: Sintaks asas fungsi exec adalah seperti berikut: exec

Antara muka output audio digital pada papan induk-SPDIF OUT Antara muka output audio digital pada papan induk-SPDIF OUT Jan 14, 2024 pm 04:42 PM

Urutan talian sambungan SPDIFOUT pada papan induk Baru-baru ini, saya menghadapi masalah mengenai urutan pendawaian wayar. Saya menyemak dalam talian Beberapa maklumat mengatakan bahawa 1, 2, dan 4 sepadan dengan keluar, +5V, dan tanah manakala maklumat lain mengatakan bahawa 1, 2, dan 4 sepadan dengan keluar, tanah dan +5V. Cara terbaik ialah menyemak manual papan induk anda Jika anda tidak menemui manual, anda boleh menggunakan multimeter untuk mengukurnya. Cari tanah dahulu, kemudian anda boleh menentukan susunan pendawaian yang lain. Cara menyambung pendawaian VDG papan induk Apabila menyambungkan pendawaian VDG papan induk, anda perlu palamkan satu hujung kabel VGA ke antara muka VGA monitor dan hujung satu lagi ke antara muka VGA kad grafik komputer. Sila berhati-hati untuk tidak memasukkannya ke dalam port VGA motherboard. Setelah disambungkan, anda boleh

Pengenalan terperinci sama ada pemproses i5 boleh memasang win11 Pengenalan terperinci sama ada pemproses i5 boleh memasang win11 Dec 27, 2023 pm 05:03 PM

i5 ialah siri pemproses yang dimiliki oleh Intel Ia mempunyai pelbagai versi generasi ke-11 i5, dan setiap generasi mempunyai prestasi yang berbeza. Oleh itu, sama ada pemproses i5 boleh memasang win11 bergantung pada generasi pemproses itu Mari ikuti editor untuk mempelajarinya secara berasingan. Bolehkah pemproses i5 dipasang dengan win11: Jawapan: pemproses i5 boleh dipasang dengan win11. 1. Pemproses i51 generasi kelapan dan seterusnya, generasi kelapan dan i5 seterusnya boleh memenuhi keperluan konfigurasi minimum Microsoft. 2. Oleh itu, kita hanya perlu memasuki laman web Microsoft dan memuat turun "Win11 Installation Assistant" 3. Selepas muat turun selesai, jalankan pembantu pemasangan dan ikut arahan untuk memasang Win11. 2. i51 sebelum generasi kelapan dan selepas generasi kelapan

Memperkenalkan kaedah penalaan bunyi Win 11 terkini Memperkenalkan kaedah penalaan bunyi Win 11 terkini Jan 08, 2024 pm 06:41 PM

Selepas mengemas kini kepada win11 terkini, ramai pengguna mendapati bahawa bunyi sistem mereka telah berubah sedikit, tetapi mereka tidak tahu bagaimana untuk menyesuaikannya Jadi hari ini laman web ini membawakan anda pengenalan kepada kaedah pelarasan bunyi win11 terkini untuk komputer anda. Ia tidak sukar untuk dikendalikan dan pilihannya pelbagai, datang dan muat turun dan cuba. Cara melaraskan bunyi sistem komputer terkini Windows 11 1. Mula-mula, klik kanan ikon bunyi di sudut kanan bawah desktop dan pilih "Tetapan Main Semula". 2. Kemudian masukkan tetapan dan klik "Speaker" dalam bar main balik. 3. Kemudian klik "Properties" di bahagian bawah sebelah kanan. 4. Klik bar pilihan "Tingkatkan" dalam sifat. 5. Pada masa ini, jika √ di hadapan "Lumpuhkan semua kesan bunyi" ditandakan, batalkannya. 6. Selepas itu, anda boleh memilih kesan bunyi di bawah untuk ditetapkan dan klik

Panduan Pemula PyCharm: Analisis Komprehensif Fungsi Penggantian Panduan Pemula PyCharm: Analisis Komprehensif Fungsi Penggantian Feb 25, 2024 am 11:15 AM

PyCharm ialah persekitaran pembangunan bersepadu Python yang berkuasa dengan fungsi dan alatan yang kaya yang boleh meningkatkan kecekapan pembangunan dengan ketara. Antaranya, fungsi penggantian merupakan salah satu fungsi yang kerap digunakan dalam proses pembangunan, yang boleh membantu pembangun mengubah suai kod dengan cepat dan meningkatkan kualiti kod. Artikel ini akan memperkenalkan fungsi gantian PyCharm secara terperinci, digabungkan dengan contoh kod khusus, untuk membantu orang baru menguasai dan menggunakan fungsi ini dengan lebih baik. Pengenalan kepada fungsi gantian Fungsi gantian PyCharm boleh membantu pembangun dengan cepat menggantikan teks yang ditentukan dalam kod

See all articles