cari
RumahTutorial sistemLINUXBagaimana untuk mereka bentuk jadual MySQL berprestasi tinggi

Bagaimana untuk mereka bentuk jadual MySQL berprestasi tinggi

Jan 07, 2024 pm 11:54 PM
linuxtutorial linuxTopi Merahsistem linuxarahan linuxpensijilan linuxlinux topi merahvideo linux

Reka bentuk logik dan reka bentuk fizikal yang baik adalah asas prestasi tinggi Skema harus direka bentuk mengikut pernyataan pertanyaan yang akan dilaksanakan oleh sistem, yang selalunya memerlukan penimbangan pelbagai faktor.

Bagaimana untuk mereka bentuk jadual MySQL berprestasi tinggi

1. Pilih jenis data yang dioptimumkan

MySQL menyokong banyak jenis data Memilih jenis data yang betul adalah penting untuk mencapai prestasi tinggi.

Lebih kecil selalunya lebih baik

Jenis data yang lebih kecil biasanya lebih pantas kerana ia menduduki lebih sedikit cakera, memori dan cache CPU serta memerlukan lebih sedikit kitaran CPU untuk diproses.

Sederhana sahaja

Operasi pada jenis data ringkas biasanya memerlukan lebih sedikit kitaran CPU. Contohnya, operasi integer adalah lebih murah daripada operasi aksara kerana set aksara dan peraturan penyusunan (collation) menjadikan perbandingan aksara lebih kompleks daripada perbandingan integer.

Cuba elakkan NULL

Jika pertanyaan mengandungi lajur NULL, MySQL lebih sukar untuk dioptimumkan kerana lajur NULL menjadikan indeks, statistik indeks dan perbandingan nilai lebih kompleks. Lajur yang boleh NULL menggunakan lebih banyak ruang storan dan memerlukan pengendalian khas dalam MySQL. Apabila lajur NULLable diindeks, setiap rekod indeks memerlukan bait tambahan, yang dalam MyISAM malah boleh menyebabkan indeks saiz tetap (seperti indeks dengan hanya satu lajur integer) menjadi indeks saiz berubah-ubah.

Sudah tentu terdapat pengecualian Sebagai contoh, InnoDB menggunakan bit yang berasingan untuk menyimpan nilai NULL, jadi ia mempunyai kecekapan ruang yang baik untuk data yang jarang.

1. Jenis integer

Terdapat dua jenis nombor: nombor bulat dan nombor nyata. Jika anda menyimpan integer, anda boleh menggunakan jenis integer ini: TINYINT, SMALLINT, MEDIUMINT, INT, BIGINT. Gunakan ruang storan 8, 16, 24, 32 dan 64-bit masing-masing.

Jenis integer mempunyai atribut **UNSIGNED** pilihan, yang bermaksud nilai negatif tidak dibenarkan, yang secara kasarnya menggandakan had atas nombor positif. Contohnya, TINYINT.UNSIGNED boleh menyimpan julat 0 - 255, manakala julat storan TINYINT ialah -128 -127.

Jenis yang ditandatangani dan yang tidak ditandatangani menggunakan ruang storan yang sama dan mempunyai prestasi yang sama, jadi anda boleh memilih jenis yang sesuai mengikut situasi sebenar.

Pilihan anda menentukan cara MySQL menyimpan data dalam memori dan cakera. Walau bagaimanapun, pengiraan integer biasanya menggunakan integer BIGINT 64-bit, walaupun dalam persekitaran 32-bit. (Pengecualian ialah beberapa fungsi agregat, yang menggunakan PERPULUHAN atau GANDA untuk pengiraan).

MySQL boleh menentukan lebar untuk jenis integer, seperti INT(11), yang tidak bermakna untuk kebanyakan aplikasi: ia tidak mengehadkan julat nilai yang sah, tetapi hanya menentukan beberapa alat interaktif MySQL (seperti pelanggan baris arahan MySQL ) Digunakan untuk memaparkan bilangan aksara. Untuk tujuan penyimpanan dan pengiraan, INT(1) dan INT(20) adalah sama.

2.Jenis nombor sebenar

Nombor sebenar ialah nombor dengan bahagian perpuluhan. Walau bagaimanapun, ia bukan sahaja untuk menyimpan bahagian perpuluhan, DECIMAL juga boleh digunakan untuk menyimpan integer yang lebih besar daripada BIGINT.

Jenis FLOAT dan DOUBLE menyokong pengiraan anggaran menggunakan operasi titik terapung standard.

Jenis PERPULUHAN digunakan untuk menyimpan perpuluhan yang tepat.

Kedua-dua jenis titik terapung dan DECIMAL boleh menentukan ketepatan. Untuk lajur DECIMAL, anda boleh menentukan bilangan maksimum digit yang dibenarkan sebelum dan selepas titik perpuluhan. Ini menjejaskan penggunaan ruang lajur.

Terdapat pelbagai cara untuk menentukan ketepatan yang diperlukan untuk lajur titik terapung, yang akan menyebabkan MySQL memilih jenis data yang berbeza, atau untuk membulatkan nilai semasa menyimpan. Takrifan ketepatan ini bukan standard, jadi kami mengesyorkan untuk menentukan jenis data sahaja dan bukan ketepatannya.

Jenis titik terapung biasanya menggunakan ruang yang kurang daripada PERPULUHAN apabila menyimpan nilai dalam julat yang sama. FLOAT menggunakan 4 bait storan. DOUBLE menduduki 8 bait dan mempunyai ketepatan yang lebih tinggi dan julat yang lebih besar daripada FLOAT. Seperti jenis integer, semua yang anda boleh pilih ialah jenis storan menggunakan DOUBLE sebagai jenis pengiraan titik terapung dalaman.

Oleh kerana ruang tambahan dan overhed pengiraan diperlukan, anda harus cuba menggunakan PERPULUHAN sahaja apabila melakukan pengiraan tepat pada perpuluhan. Tetapi apabila data agak besar, anda boleh mempertimbangkan untuk menggunakan BIGINT dan bukannya PERPULUHAN Hanya darabkan unit mata wang untuk disimpan dengan gandaan yang sepadan mengikut bilangan tempat perpuluhan.

3. Jenis rentetan

VARCHAR

  • Digunakan untuk menyimpan rentetan berubah-ubah, panjangnya disokong hingga 65535
  • Memerlukan 1 atau 2 bait tambahan untuk merekodkan panjang rentetan
  • Sesuai untuk: Panjang maksimum rentetan adalah lebih besar daripada panjang purata yang jarang berlaku

CHAR

  • Panjang tetap, julat panjang ialah 1~255
  • Sesuai untuk: menyimpan rentetan yang sangat pendek, atau semua nilai yang hampir sama panjangnya

Pemurah itu tidak bijak

Ruang atas untuk menyimpan 'hello' menggunakan VARCHAR(5) dan VARCHAR(200) adalah sama. Jadi adakah terdapat sebarang kelebihan untuk menggunakan lajur yang lebih pendek?

Ternyata mempunyai kelebihan yang besar. Lajur yang lebih panjang menggunakan lebih banyak memori kerana MySQL biasanya memperuntukkan blok memori bersaiz tetap untuk menyimpan nilai dalaman. Ini amat teruk apabila menggunakan jadual sementara dalam ingatan untuk pengisihan atau operasi. Ia sama buruk apabila mengisih menggunakan jadual sementara cakera.

Jadi strategi terbaik ialah memperuntukkan hanya ruang yang anda perlukan sahaja.

4.Jenis BLOB dan TEKS

BLOB dan TEXT ialah kedua-dua jenis data rentetan yang direka untuk menyimpan data yang besar, dan masing-masing disimpan dalam mod binari dan aksara.

Tidak seperti jenis lain, MySQL menganggap setiap nilai BLOB dan TEKS sebagai objek bebas. Enjin storan biasanya melakukan pemprosesan khas semasa menyimpan. Apabila nilai BLOB dan TEXT terlalu besar, InnoDB akan menggunakan kawasan storan "luaran" khusus untuk storan Pada masa ini, setiap nilai memerlukan 1 - 4 bait untuk disimpan dalam baris .

Satu-satunya perbezaan antara BLOB dan TEXT ialah jenis BLOB menyimpan data binari dan tidak mempunyai himpunan atau set aksara, manakala jenis TEXT mempunyai set aksara dan pengumpulan

5.Tarikh dan masa jenis

Selalunya tiada alternatif kepada jenis tersebut, jadi tidak timbul persoalan apakah pilihan terbaik. Satu-satunya masalah ialah apa yang perlu dilakukan apabila menyimpan tarikh dan masa. MySQL menyediakan dua jenis tarikh yang serupa: DATE TIME dan TIMESTAMP.

Tetapi pada masa ini kami lebih suka kaedah menyimpan cap waktu, jadi DATE TIME dan TIMESTAMP tidak akan dijelaskan di sini.

6.Lain-lain jenis

6.1 Pilih Pengecam

Jenis data terkecil harus dipilih atas premis bahawa ia boleh memenuhi keperluan julat nilai dan memberi ruang untuk pertumbuhan masa hadapan.

  • Jenis integer

Integer biasanya merupakan pilihan terbaik untuk lajur identiti kerana ia pantas dan boleh menggunakan AUTO_INCREMENT.

  • Jenis ENUM dan SET

Jenis EMUM dan SET biasanya merupakan pilihan yang tidak baik untuk lajur identiti, walaupun ia mungkin baik untuk sesetengah "jadual definisi" statik yang hanya mengandungi keadaan atau jenis tetap. Lajur ENUM dan SET sesuai untuk menyimpan maklumat tetap, seperti status pesanan, jenis produk dan jantina seseorang.

  • Jenis rentetan

Jika boleh, jenis rentetan harus dielakkan sebagai lajur identiti, kerana ia memakan ruang dan biasanya lebih perlahan daripada jenis angka.

Anda juga perlu memberi lebih perhatian kepada rentetan "rawak" sepenuhnya, seperti rentetan yang dijana oleh MDS(), SHAl() atau UUID(). Nilai baharu yang dijana oleh fungsi ini diedarkan secara sewenang-wenangnya pada ruang yang besar, yang boleh menyebabkan INSERT dan beberapa pernyataan SELECT menjadi sangat perlahan. Jika nilai UUID disimpan, tanda "-" harus dialih keluar.

6.2 Data jenis khas

Sesetengah jenis telaga data tidak sepadan secara langsung dengan jenis terbina dalam. Cap masa dengan ketepatan kilosaat yang rendah ialah satu contoh contoh lain ialah alamat 1Pv4 Orang sering menggunakan lajur VARCHAR(15) untuk menyimpan alamat IP, ia sebenarnya 32-bit integer, bukan rentetan. Perwakilan alamat dibahagikan kepada empat segmen menggunakan titik perpuluhan hanyalah untuk memudahkan orang ramai membaca. Jadi alamat IP harus disimpan sebagai integer tidak bertanda. MySQL menyediakan fungsi INET_ATON() dan INET_NTOA() untuk menukar antara dua kaedah perwakilan ini.

2. Reka bentuk struktur meja

1. Paradigma dan anti-paradigma

Biasanya terdapat banyak cara untuk mewakili mana-mana data yang diberikan, daripada dinormalisasi sepenuhnya kepada dinyahnormalkan sepenuhnya dan kompromi antara kedua-duanya. Dalam pangkalan data yang dinormalkan, setiap fakta muncul tepat sekali. Sebaliknya, dalam pangkalan data yang tidak normal, maklumat adalah berlebihan dan mungkin disimpan di beberapa tempat.

Kebaikan dan keburukan paradigma

Apabila mempertimbangkan peningkatan prestasi, selalunya disyorkan untuk menormalkan skema, terutamanya dalam senario intensif tulis.

  • Operasi kemas kini yang dinormalkan biasanya lebih cepat daripada yang dinyahnormalkan.
  • Apabila data dinormalisasi dengan baik, terdapat sedikit atau tiada data pendua, jadi kurang data yang perlu diubah suai.
  • Jadual biasa biasanya lebih kecil dan lebih sesuai dalam ingatan, jadi operasi akan dilakukan dengan lebih cepat.
  • Kurang data berlebihan bermakna lebih sedikit penyataan DISTINCT atau GROUP BY diperlukan semasa mendapatkan data senarai.

Kebaikan dan keburukan anti-paradigma

Tiada keperluan untuk jadual yang berkaitan, jadi senario kes terburuk untuk kebanyakan pertanyaan—walaupun jadual tidak menggunakan indeks—adalah imbasan jadual penuh. Ini boleh menjadi lebih pantas daripada bersekutu apabila data lebih besar daripada memori kerana I/0 rawak dielakkan.

Jadual individu juga boleh menggunakan strategi pengindeksan yang lebih cekap.

Mencampurkan normalisasi dan denormalisasi

Dalam aplikasi praktikal, ia selalunya perlu dicampur, dan sebahagian skema yang dinormalkan, jadual cache dan teknik lain boleh digunakan.

Tambahkan medan berlebihan pada jadual dengan sewajarnya, seperti keutamaan prestasi, tetapi ia akan meningkatkan kerumitan. Pertanyaan menyertai jadual boleh dielakkan.

Mudah dan biasa dengan paradigma pangkalan data

<br> Bentuk normal pertama (1NF): Nilai medan adalah atom dan tidak boleh dibahagikan (semua sistem pangkalan data hubungan memenuhi bentuk normal pertama);<br> Contohnya: medan nama, di mana nama keluarga dan nama pertama adalah keseluruhan Jika nama keluarga dan nama pertama dibezakan, dua medan bebas mesti disediakan;

.

Borang Normal Kedua (2NF): Jadual mesti mempunyai kunci utama, iaitu setiap baris data boleh dibezakan secara unik;
Nota: Bentuk normal pertama mesti dipenuhi dahulu;

Borang Normal Ketiga (3NF): Jadual tidak boleh mengandungi maklumat tentang medan bukan kunci dalam jadual lain yang berkaitan, iaitu jadual data tidak boleh mempunyai medan berlebihan;
Nota: Bentuk normal kedua mesti dipenuhi dahulu;

2. Medan jadual kurang halus

  • I/O cekap
  • Ladang diasingkan dan diselenggara dengan mudah
  • Jadual tunggal 1G volum 500W penilaian baris
  • Satu baris tidak boleh melebihi 200Byte
  • Tidak lebih daripada 50 medan INT dalam satu jadual
  • Tidak lebih daripada 20 CHAR(10) medan dalam satu jadual
  • Adalah disyorkan bahawa bilangan medan dalam satu jadual dikawal dalam masa 20
  • Split TEXT/BLOB, prestasi pemprosesan jenis TEXT jauh lebih rendah daripada VARCHAR, memaksa penjanaan jadual sementara cakera keras membazir lebih banyak ruang.

Atas ialah kandungan terperinci Bagaimana untuk mereka bentuk jadual MySQL berprestasi tinggi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Artikel ini dikembalikan pada:Linux就该这么学. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
Apakah gaji Pentadbir Linux?Apakah gaji Pentadbir Linux?Apr 17, 2025 am 12:24 AM

Purata gaji tahunan pentadbir Linux ialah $ 75,000 hingga $ 95,000 di Amerika Syarikat dan € 40,000 hingga € 60,000 di Eropah. Untuk meningkatkan gaji, anda boleh: 1. Secara berterusan mempelajari teknologi baru, seperti pengkomputeran awan dan teknologi kontena; 2. Mengumpulkan pengalaman projek dan menubuhkan portfolio; 3. Mewujudkan rangkaian profesional dan mengembangkan rangkaian anda.

Apakah tujuan utama Linux?Apakah tujuan utama Linux?Apr 16, 2025 am 12:19 AM

Penggunaan utama Linux termasuk: 1. Sistem Operasi Pelayan, 2. Sistem Terbenam, 3. Linux cemerlang dalam bidang ini, menyediakan kestabilan, keselamatan dan alat pembangunan yang cekap.

Adakah Internet berjalan di Linux?Adakah Internet berjalan di Linux?Apr 14, 2025 am 12:03 AM

Internet tidak bergantung pada sistem operasi tunggal, tetapi Linux memainkan peranan penting di dalamnya. Linux digunakan secara meluas dalam pelayan dan peranti rangkaian dan popular untuk kestabilan, keselamatan dan skalabiliti.

Apakah operasi Linux?Apakah operasi Linux?Apr 13, 2025 am 12:20 AM

Inti sistem pengendalian Linux adalah antara muka baris arahannya, yang boleh melakukan pelbagai operasi melalui baris arahan. 1. Operasi Fail dan Direktori Gunakan LS, CD, MKDIR, RM dan arahan lain untuk menguruskan fail dan direktori. 2. Pengguna dan Pengurusan Kebenaran Memastikan keselamatan sistem dan peruntukan sumber melalui UserAdd, Passwd, CHMOD dan arahan lain. 3. Pengurusan proses menggunakan PS, membunuh dan arahan lain untuk memantau dan mengawal proses sistem. 4. Operasi rangkaian termasuk PING, IFCONFIG, SSH dan arahan lain untuk mengkonfigurasi dan menguruskan sambungan rangkaian. 5. Pemantauan sistem dan penyelenggaraan sistem seperti TOP, DF, DU untuk memahami status operasi sistem dan penggunaan sumber.

Meningkatkan Produktiviti dengan Pintasan Perintah Custom Menggunakan Linux AliasesMeningkatkan Produktiviti dengan Pintasan Perintah Custom Menggunakan Linux AliasesApr 12, 2025 am 11:43 AM

Pengenalan Linux adalah sistem operasi yang kuat yang disukai oleh pemaju, pentadbir sistem, dan pengguna kuasa kerana fleksibiliti dan kecekapannya. Walau bagaimanapun, kerap menggunakan arahan panjang dan kompleks boleh membosankan dan er

Apa yang sebenarnya Linux?Apa yang sebenarnya Linux?Apr 12, 2025 am 12:20 AM

Linux sesuai untuk pelayan, persekitaran pembangunan, dan sistem tertanam. 1. Sebagai sistem pengendalian pelayan, Linux stabil dan cekap, dan sering digunakan untuk menggunakan aplikasi konkurasi tinggi. 2. Sebagai persekitaran pembangunan, Linux menyediakan alat arahan dan sistem pengurusan pakej yang cekap untuk meningkatkan kecekapan pembangunan. 3. Dalam sistem tertanam, Linux ringan dan disesuaikan, sesuai untuk persekitaran dengan sumber yang terhad.

Alat dan kerangka penting untuk menguasai penggodaman etika di LinuxAlat dan kerangka penting untuk menguasai penggodaman etika di LinuxApr 11, 2025 am 09:11 AM

Pengenalan: Mengamankan sempadan digital dengan penggodaman etika berasaskan Linux Di dunia yang semakin saling berkaitan, keselamatan siber adalah yang paling penting. Ujian penggodaman dan penembusan etika adalah penting untuk mengenal pasti dan mengurangkan keruntuhan secara proaktif

Bagaimana untuk belajar asas Linux?Bagaimana untuk belajar asas Linux?Apr 10, 2025 am 09:32 AM

Kaedah untuk pembelajaran asas Linux dari awal termasuk: 1. Memahami sistem fail dan antara muka baris perintah, 2. Master arahan asas seperti LS, CD, MKDIR, 3.

See all articles

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)
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa