Rumah pangkalan data tutorial mysql 为什么全表扫描成本(COST)公式里面要除以sreadtim

为什么全表扫描成本(COST)公式里面要除以sreadtim

Jun 07, 2016 pm 04:04 PM
cost sre kenapa rasmi kos mengimbas

全表扫描的成本计算公式 如下: Cost = ( #SRds * sreadtim + #MRds * mreadtim + CPUCycles / cpuspeed ) / sreadtim 全表扫描的时候,单块读次数=0,#SRds表示单块读次数。全表扫描的成本里面,CPU消耗其实非常少,可以忽略不计,所以全表扫描的公式可以改

全表扫描的成本计算公式 如下:

Cost = (
       #SRds * sreadtim +
       #MRds * mreadtim +
       CPUCycles / cpuspeed
       ) / sreadtim
Salin selepas log masuk

全表扫描的时候,单块读次数=0,#SRds表示单块读次数。全表扫描的成本里面,CPU消耗其实非常少,可以忽略不计,所以全表扫描的公式可以改写为:

Cost = #MRds * mreadtim  / sreadtim
Salin selepas log masuk

#MRds 表示多块读io次数

mreadtim 表示一次多块读耗费时间

sreadtim 表示一次单块读耗费时间

全表扫描的COST意思其实就是 多块读io次数 * 多块读时间 / 单块读时间

那么为什么 全表扫描成本公式里面要除以 sreadtim呢? 我们来看一下 索引扫描的成本计算公式:

cost =  
 blevel +  
 celiling(leaf_blocks *effective index selectivity) +  
 celiling(clustering_factor * effective table selectivity)  
Salin selepas log masuk

blevel 是 扫描索引 的 root到branch ---单块读

celiling(leaf_blocks *effective index selectivity) 是扫描的 也在块的个数 ---单块读

ceiling(clustering_factor*effective table selectivity) 是 通过索引的rowid回表的次数 ---单块读

那么 索引扫描的成本公式的本质含义 其实就是 单块读的 io次数

对于单表访问(什么是单表访问? 就是只select一个表),要么走全表扫描,要么走索引扫描,当然了还可以走物化视图(这个不考虑)

ORACLE 究竟是走全表扫描还是走索引扫描呢? 它是计算全表扫描的COST,计算索引扫描的COST 哪个COST消耗少就走哪个。

问题来了,为啥ORACLE计算COST能准确的判断走哪个是最优的呢? 现在我们来比较一下 全表扫描的 COST 与 索引扫描的COST

全表扫描COST 多块读io次数 * 多块读时间 / 单块读时间

索引扫描COST 单块读io次数

那么现在 我们都对 全表扫描 COST , 都对 索引扫描 COST 乘以一个 单块读时间

全表扫描COST* 单块读时间 = 多块读io次数*多块读时间 = 总的耗费时间

索引扫描COST* 单块读时间 = 单块读io次数*单块读时间 = 总的耗费时间

说白了,就是比较全表扫描与索引扫描谁 总的耗费的时间最少,就选谁。

到这里你应该看懂了吧。 不得不佩服ORACLE 设计 人员的头脑,真是牛逼。

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

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)

Kenapa kawasan -kawasan yang dikurangkan ungu di susun atur flex tersilap dianggap sebagai 'ruang limpahan'? Kenapa kawasan -kawasan yang dikurangkan ungu di susun atur flex tersilap dianggap sebagai 'ruang limpahan'? Apr 05, 2025 pm 05:51 PM

Soalan mengenai kawasan slash ungu dalam susun atur flex Apabila menggunakan susun atur flex, anda mungkin menghadapi beberapa fenomena yang mengelirukan, seperti dalam alat pemaju (D ...

Adakah pengeluaran halaman H5 memerlukan penyelenggaraan berterusan? Adakah pengeluaran halaman H5 memerlukan penyelenggaraan berterusan? Apr 05, 2025 pm 11:27 PM

Halaman H5 perlu dikekalkan secara berterusan, kerana faktor -faktor seperti kelemahan kod, keserasian pelayar, pengoptimuman prestasi, kemas kini keselamatan dan peningkatan pengalaman pengguna. Kaedah penyelenggaraan yang berkesan termasuk mewujudkan sistem ujian lengkap, menggunakan alat kawalan versi, kerap memantau prestasi halaman, mengumpul maklum balas pengguna dan merumuskan pelan penyelenggaraan.

Bolehkah JS berjalan tanpa H5? Bolehkah JS berjalan tanpa H5? Apr 06, 2025 am 09:06 AM

Adakah JavaScript tersedia tanpa html5? Enjin JavaScript sendiri boleh berjalan secara bebas. Menjalankan JavaScript dalam persekitaran penyemak imbas bergantung kepada HTML5 kerana ia menyediakan persekitaran yang standard yang diperlukan untuk memuat dan melaksanakan kod. API dan ciri -ciri yang disediakan oleh HTML5 adalah penting untuk kerangka dan perpustakaan JavaScript moden. Tanpa persekitaran HTML5, banyak ciri JavaScript sukar dilaksanakan atau tidak dapat dilaksanakan.

Kenapa lembaran gaya tersuai berkuatkuasa pada laman web tempatan di Safari tetapi tidak di halaman Baidu? Kenapa lembaran gaya tersuai berkuatkuasa pada laman web tempatan di Safari tetapi tidak di halaman Baidu? Apr 05, 2025 pm 05:15 PM

Perbincangan Menggunakan Stylesheets Custom Di Safari Hari Ini Kami akan membincangkan soalan mengenai penggunaan gaya gaya tersuai untuk penyemak imbas Safari. Pemula depan ...

Apakah kelebihan pengeluaran halaman H5 Apakah kelebihan pengeluaran halaman H5 Apr 05, 2025 pm 11:48 PM

Kelebihan pengeluaran halaman H5 termasuk: pengalaman ringan, kelajuan pemuatan cepat, dan peningkatan pengekalan pengguna. Keserasian silang platform, tidak perlu menyesuaikan diri dengan platform yang berbeza, meningkatkan kecekapan pembangunan. Fleksibiliti dan kemas kini dinamik, tiada audit diperlukan, menjadikannya lebih mudah untuk mengubah suai dan mengemas kini kandungan. Kos efektif, kos pembangunan yang lebih rendah daripada aplikasi asli.

Tidak dapat log masuk ke mysql sebagai akar Tidak dapat log masuk ke mysql sebagai akar Apr 08, 2025 pm 04:54 PM

Sebab utama mengapa anda tidak boleh log masuk ke MySQL sebagai akar adalah masalah kebenaran, ralat fail konfigurasi, kata laluan tidak konsisten, masalah fail soket, atau pemintasan firewall. Penyelesaiannya termasuk: periksa sama ada parameter pengikat di dalam fail konfigurasi dikonfigurasi dengan betul. Semak sama ada kebenaran pengguna root telah diubahsuai atau dipadam dan ditetapkan semula. Sahkan bahawa kata laluan adalah tepat, termasuk kes dan aksara khas. Semak tetapan dan laluan kebenaran fail soket. Semak bahawa firewall menyekat sambungan ke pelayan MySQL.

Mengapa elemen Div tertentu dalam penyemak imbas tepi tidak dipaparkan? Bagaimana menyelesaikan masalah ini? Mengapa elemen Div tertentu dalam penyemak imbas tepi tidak dipaparkan? Bagaimana menyelesaikan masalah ini? Apr 05, 2025 pm 08:21 PM

Bagaimana menyelesaikan masalah paparan yang disebabkan oleh helaian gaya ejen pengguna? Apabila menggunakan penyemak imbas Edge, elemen Div dalam projek tidak dapat dipaparkan. Setelah memeriksa, saya menyiarkan ...

Hubungan antara meja bootstrap dihiasi dan pengekodan halaman Hubungan antara meja bootstrap dihiasi dan pengekodan halaman Apr 07, 2025 pm 12:03 PM

Jadual Bootstrap Kod Garbled biasanya kerana pengekodan halaman tidak konsisten dengan pengekodan data jadual. Untuk menyelesaikan masalah ini, anda perlu memastikan ia konsisten. Langkah -langkah khusus termasuk: menyemak halaman dan pengekodan data jadual, menetapkan pengekodan halaman, dan mengesahkan pengekodan. Jika UTF-8 digunakan, pelayan juga harus menyokongnya. Jika ia tidak dapat diselesaikan, cuba gunakan perpustakaan pengekodan JavaScript.

See all articles