Rumah pangkalan data tutorial mysql MySQL的优化方法总结_MySQL

MySQL的优化方法总结_MySQL

Jun 01, 2016 pm 01:50 PM
Pengoptimuman pangkalan data

bitsCN.com

  数据库优化是一项很复杂的工作,因为这最终需要对系统优化的很好理解才行。尽管对系统或应用系统的了解不多的情况下优化效果还不错,但是如果想优化的效果更好,那么就需要对它了解更多才行。

  1、优化概述

  让系统运行得快得最重要因素是数据库基本的设计。并且还必须清楚您的系统要用来做什么,以及存在的瓶颈。

  最常见的系统瓶颈有以下几种:

  磁盘搜索。它慢慢地在磁盘中搜索数据块。对现代磁盘来说,平时的搜索时间基本上小于10毫秒,因此理论上每秒钟可以做100次磁盘搜索。这个时间对于全新的新磁盘来说提高的不多,并且对于只有一个表的情况也是如此。加快搜索时间的方法是将数据分开存放到多个磁盘中。

  磁盘读/写。当磁盘在正确的位置上时,就需要读取数据。对现代磁盘来说,磁盘吞吐量至少是10-20MB/秒。这比磁盘搜索的优化更容易,因为可以从多个媒介中并行地读取数据。

  CPU周期。数据存储在主内存中(或者它已经在主内存中了),这就需要处理这些数据以得到想要的结果。

  内存带宽。当CPU要将更多的数据存放在CPU缓存中时,主内存的带宽就是瓶颈了。在大多数系统中,这不是常见的瓶颈,不过也是要注意的一个因素。

  1.1 MySQL 设计的局限性

  当使用MyISAM存储引擎时,MySQL会使用一个快速数据表锁以允许同时多个读取和一个写入。这种存储引擎的最大问题是发生在一个单一的表上同时做稳定的更新操作及慢速查询。如果这种情况在某个表中存在,可以使用另一种表类型。

  MySQL可以同时在事务及非事务表下工作。为了能够平滑的使用非事务表(发生错误时不能回滚),有以下几条规则:

  所有的字段都有默认值

  如果字段中插入了一个"错误"的值,比如在数字类型字段中插入过大数值,那么MySQL会将该字段值置为"最可能的值"而不是给出一个错误。数字类型的值是0,最小或者最大的可能值。字符串类型,不是空字符串就是字段所能存储的最大长度。

  所有的计算表达式都会返回一个值而报告条件错误,例如 1/0 返回 NULL。

  这些规则隐含的意思是,不能使用MySQL来检查字段内容。相反地,必须在存储到数据库前在应用程序中来检查。

  1.2 应用设计的可移植性

  由于各种不同的数据库实现了各自的SQL标准,这就需要我们尽量使用可移植的SQL应用。查询和插入操作很容易就能做到可移植,不过由于更多的约束条件的要求就越发困难。想要让一个应用在各种数据库系统上快速运行,就变得更困难了。

  为了能让一个复杂的应用做到可移植,就要先看这个应用运行于哪种数据库系统之上,然后看这些数据库系统都支持哪些特性。每个数据库系统都有某些不足。也就是说,由于设计上的一些妥协,导致了性能上的差异。

  可以用MySQL的 crash-me 程序来看选定的数据库服务器上可以使用的函数,类型,限制等。crash-me 不会检查各种可能存在的特性,不过这仍然是合乎情理的理解,大约做了450次测试。一个crash-me 的信息类型的例子就是,它会告诉您如果想使用Informix 或 DB2的话,就不能使字段名长度超过18个字符。

  crash-me 程序和MySQL基准使每个准数据库都实现了的。可以通过阅读这些基准程序是怎么写的,自己就大概有怎样做才能让程序独立于各种数据库这方面的想法了。这些程序可以在MySQL源代码的 `sql-bench' 目录下找到。他们大部分都是用Perl写的,并且使用DBI接口。由于它提供了独立于数据库的各种访问方式,因此用DBI来解决各种移植性的问题。

  如果您想努力做到独立于数据库,这就需要对各种SQL服务器的瓶颈都有一些很好的想法。例如,MySQL对于 MyISAM 类型的表在检索以及更新记录时非常快,但是在有并发的慢速读取及写入记录时却有一定的问题。作为Oracle来说,它在访问刚刚被更新的记录时有很大的问题(直到结果被刷新到磁盘中)。事务数据库一般地在从日志表中生成摘要表这方面的表现不怎么好,因为在这种情况下,行记录锁几乎没用。

  为了能让应用程序真正的做到独立于数据库,就必须把操作数据的接口定义的简单且可扩展。由于C++在很多系统上都可以使用,因此使用C++作为数据库的基类结果很合适。

  如果使用了某些数据库独有的特定功能(比如 REPLACE 语句就只在MySQL中独有),这就需要通过编写替代方法来在其他数据库中实现这个功能。尽管这些替代方法可能会比较慢,但是它能让其他数据库实现同样的功能。

  在MySQL中,可以在查询语句中使用 /*! */ 语法来增加MySQL特有的关键字。然而在很多其他数据库中,/**/ 却被当成了注释(并且被忽略)。

  如果有时候更高的性能比数据结果的精确更重要,就像在一些Web应用中那样,这可以使用一个应用层来缓存结果,这可能会有更高的性能。通过让旧数据在一定时间后过期,来合理的更新缓存。这是处理负载高峰期时的一种方法,这种情况下,可以通过加大缓存容量和过期时间直到负载趋于正常。

  这种情况下,建表信息中就要包含了初始化缓存的容量以及正常刷新数据表的频率。一个实现应用层缓存的可选方案是使用MySQL的查询缓存(query cache)。启用查询缓存后,数据库就会根据一些详情来决定哪些结果可以被重用。它大大简化了应用程序。

  1.3 我们都用MySQL来做什么

  在MySQL最开始的开发过程中,MySQL本来是要准备给大客户用的,他们是瑞典的2个最大的零售商,他们用于货物存储数据管理。

  我们每周从所有的商店中得到交易利润累计结果,以此给商店的老板提供有用的信息,帮助他们分析如果更好的打广告以影响他们的客户。

  数据量相当的大(每个月的交易累计结果大概有7百万),而且还需要显示4-10年间的数据。我们每周都得到客户的需求,他们要求能‘瞬间’地得到数据的最新报表。

  我们把每个月的全部信息存储在一个压缩的‘交易’表中以解决这个问题。我们有一些简单的宏指令集,它们能根据不同的标准从存储的‘交易’表中根据字段分组(产品组、客户id、商店等等)取得结果。我们用一个小Perl脚本动态的生成Web页面形式的报表。这个脚本解析Web页面,执行SQL语句,并且插入结果。我们还可以用PHP或者mod_perl来做这个工作,不过当时还没有这2个工具。

bitsCN.com
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

Repo: Cara menghidupkan semula rakan sepasukan
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
1 bulan 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)

Bagaimanakah Hibernate mengoptimumkan prestasi pertanyaan pangkalan data? Bagaimanakah Hibernate mengoptimumkan prestasi pertanyaan pangkalan data? Apr 17, 2024 pm 03:00 PM

Petua untuk mengoptimumkan prestasi pertanyaan Hibernate termasuk: menggunakan pemuatan malas untuk menangguhkan pemuatan koleksi dan objek yang berkaitan untuk menggabungkan operasi kemas kini, memadam atau memasukkan menggunakan cache peringkat kedua untuk menyimpan objek yang sering ditanya dalam ingatan; , dapatkan semula entiti dan entiti yang berkaitan dengannya untuk mengelakkan mod pertanyaan SELECTN+1 untuk mendapatkan data besar dalam blok untuk meningkatkan prestasi pertanyaan tertentu;

Petua pengoptimuman prestasi Spring Boot: cipta aplikasi sepantas angin Petua pengoptimuman prestasi Spring Boot: cipta aplikasi sepantas angin Feb 25, 2024 pm 01:01 PM

SpringBoot ialah rangka kerja Java popular yang terkenal dengan kemudahan penggunaan dan pembangunan pesatnya. Walau bagaimanapun, apabila kerumitan aplikasi meningkat, isu prestasi boleh menjadi halangan. Untuk membantu anda mencipta aplikasi springBoot sepantas angin, artikel ini akan berkongsi beberapa petua pengoptimuman prestasi praktikal. Optimumkan masa permulaan Masa permulaan aplikasi adalah salah satu faktor utama pengalaman pengguna. SpringBoot menyediakan beberapa cara untuk mengoptimumkan masa permulaan, seperti menggunakan caching, mengurangkan output log dan mengoptimumkan pengimbasan laluan kelas. Anda boleh melakukan ini dengan menetapkan spring.main.lazy-initialization dalam fail application.properties

Bagaimana untuk meningkatkan kelajuan akses laman web Python melalui pengoptimuman pangkalan data? Bagaimana untuk meningkatkan kelajuan akses laman web Python melalui pengoptimuman pangkalan data? Aug 07, 2023 am 11:29 AM

Bagaimana untuk meningkatkan kelajuan akses laman web Python melalui pengoptimuman pangkalan data? Ringkasan Semasa membina tapak web Python, pangkalan data adalah komponen kritikal. Jika kelajuan capaian pangkalan data adalah perlahan, ia akan menjejaskan prestasi dan pengalaman pengguna tapak web secara langsung. Artikel ini akan membincangkan beberapa cara untuk mengoptimumkan pangkalan data anda untuk meningkatkan kelajuan akses tapak web Python anda, bersama-sama dengan beberapa kod sampel. Pengenalan Bagi kebanyakan laman web Python, pangkalan data adalah bahagian penting dalam menyimpan dan mendapatkan semula data. Jika tidak dioptimumkan, pangkalan data boleh menjadi hambatan prestasi. Buku

Java Spring Boot Keselamatan pengoptimuman prestasi: membuat sistem anda terbang Java Spring Boot Keselamatan pengoptimuman prestasi: membuat sistem anda terbang Feb 19, 2024 pm 05:27 PM

1. Pengoptimuman kod untuk mengelakkan penggunaan terlalu banyak anotasi keselamatan: Dalam Pengawal dan Perkhidmatan, cuba kurangkan penggunaan @PreAuthorize dan @PostAuthorize dan anotasi lain ini akan meningkatkan masa pelaksanaan kod. Optimumkan pernyataan pertanyaan: Apabila menggunakan springDataJPA, mengoptimumkan pernyataan pertanyaan boleh mengurangkan masa pertanyaan pangkalan data, dengan itu meningkatkan prestasi sistem. Caching maklumat keselamatan: Caching beberapa maklumat keselamatan yang biasa digunakan boleh mengurangkan bilangan capaian pangkalan data dan meningkatkan kelajuan tindak balas sistem. 2. Gunakan indeks untuk pengoptimuman pangkalan data: Mencipta indeks pada jadual yang sering ditanya boleh meningkatkan kelajuan pertanyaan pangkalan data dengan ketara. Bersihkan log dan meja sementara dengan kerap: Bersihkan log dan meja sementara dengan kerap

Bagaimana untuk meningkatkan prestasi MySQL dengan menggunakan indeks komposit Bagaimana untuk meningkatkan prestasi MySQL dengan menggunakan indeks komposit May 11, 2023 am 11:10 AM

Dalam pangkalan data MySQL, pengindeksan adalah cara yang sangat penting untuk pengoptimuman prestasi. Apabila jumlah data dalam jadual meningkat, indeks yang tidak sesuai boleh menyebabkan pertanyaan menjadi perlahan atau malah menyebabkan ranap pangkalan data. Untuk meningkatkan prestasi pangkalan data, indeks perlu digunakan secara rasional apabila mereka bentuk struktur jadual dan pernyataan pertanyaan. Indeks komposit ialah teknologi pengindeksan yang lebih maju yang meningkatkan kecekapan pertanyaan dengan menggabungkan berbilang medan sebagai indeks. Dalam artikel ini, kami akan memperincikan cara meningkatkan prestasi MySQL dengan menggunakan indeks komposit. Apakah komposit indeks komposit

Dari perspektif teknikal, mengapa Oracle boleh mengalahkan MySQL? Dari perspektif teknikal, mengapa Oracle boleh mengalahkan MySQL? Sep 08, 2023 pm 04:15 PM

Dari perspektif teknikal, mengapa Oracle boleh mengalahkan MySQL? Dalam beberapa tahun kebelakangan ini, sistem pengurusan pangkalan data (DBMS) telah memainkan peranan penting dalam penyimpanan dan pemprosesan data. Oracle dan MySQL, dua DBMS yang popular, sentiasa menarik perhatian ramai. Walau bagaimanapun, dari perspektif teknikal, Oracle lebih berkuasa daripada MySQL dalam beberapa aspek, jadi Oracle mampu mengalahkan MySQL. Pertama, Oracle cemerlang dalam mengendalikan data berskala besar. Oracl

Masalah pangkalan data biasa dalam sistem Linux dan penyelesaiannya Masalah pangkalan data biasa dalam sistem Linux dan penyelesaiannya Jun 18, 2023 pm 03:36 PM

Dengan perkembangan berterusan teknologi komputer dan pertumbuhan berterusan skala data, pangkalan data telah menjadi teknologi penting. Walau bagaimanapun, terdapat beberapa masalah biasa yang dihadapi apabila menggunakan pangkalan data dalam sistem Linux Artikel ini akan memperkenalkan beberapa masalah pangkalan data biasa dalam sistem Linux dan penyelesaiannya. Masalah sambungan pangkalan data Apabila menggunakan pangkalan data, masalah seperti kegagalan sambungan atau tamat masa sambungan kadangkala berlaku Masalah ini mungkin disebabkan oleh ralat konfigurasi pangkalan data atau hak akses yang tidak mencukupi. Penyelesaian: Semak fail konfigurasi pangkalan data untuk memastikan

Bagaimana untuk menyelesaikan masalah prestasi kemas kini pangkalan data dalam pembangunan Java Bagaimana untuk menyelesaikan masalah prestasi kemas kini pangkalan data dalam pembangunan Java Jun 29, 2023 pm 01:00 PM

Cara menyelesaikan isu prestasi kemas kini pangkalan data dalam pembangunan Java Ringkasan: Dengan peningkatan volum data dan perubahan perniagaan, isu prestasi kemas kini pangkalan data telah menjadi cabaran utama dalam pembangunan Java. Artikel ini akan memperkenalkan beberapa kaedah dan teknik biasa untuk menyelesaikan masalah prestasi kemas kini pangkalan data. Kata kunci: Pembangunan Java, pangkalan data, isu prestasi kemas kini, penyelesaian Pengenalan: Dalam kebanyakan aplikasi Java, pangkalan data memainkan peranan penting. Prestasi pangkalan data secara langsung mempengaruhi kelajuan tindak balas dan kestabilan aplikasi. Dalam perkembangan sebenar, bilangan

See all articles