Kunci utama dalam mysql bukan indeks. Nama penuh kunci utama ialah "kekangan kunci utama", yang merupakan kekangan pada data dalam jadual Ia adalah medan khas jadual, yang boleh mengenal pasti setiap maklumat dalam jadual secara unik struktur pangkalan data khas, yang terdiri daripada data Gabungan satu atau lebih lajur dalam jadual, yang boleh digunakan untuk menanya rekod dengan cepat dengan nilai tertentu dalam jadual data.
Persekitaran pengendalian tutorial ini: sistem windows7, versi mysql8, komputer Dell G3.
Kunci utama MySQL
Dalam MySQL, nama penuh kunci utama (KUNCI UTAMA) ialah "kekangan kunci utama", yang merupakan kekangan yang paling kerap digunakan dalam MySQL. Dalam keadaan biasa, untuk memudahkan DBMS mencari rekod dalam jadual dengan lebih cepat, kunci utama akan ditetapkan dalam jadual.
Kekangan merujuk kepada kekangan pada data dalam jadual, yang boleh membantu pentadbir pangkalan data mengurus pangkalan data dengan lebih baik dan memastikan ketepatan dan kesahihan data dalam pangkalan data.
Kunci primer ialah medan khas dalam jadual yang mengenal pasti secara unik setiap maklumat dalam jadual. Contohnya, nombor pelajar dalam jadual maklumat pelajar adalah unik.
Kunci utama dibahagikan kepada kunci utama satu medan dan kunci utama gabungan berbilang medan Bahagian ini akan menerangkan penciptaan, pengubahsuaian dan pemadaman kedua-dua kekangan utama ini.
Perkara berikut perlu diberi perhatian apabila menggunakan kunci utama:
Setiap jadual hanya boleh mentakrifkan satu kunci utama.
Nilai kunci utama mesti mengenal pasti secara unik setiap baris dalam jadual dan tidak boleh NULL, iaitu, tidak boleh ada dua baris data dengan nilai kunci utama yang sama dalam jadual. Ini adalah prinsip keunikan.
Nama medan hanya boleh muncul sekali dalam jadual medan kunci primer bersama.
Kunci primer bersama tidak boleh mengandungi medan berlebihan yang tidak diperlukan. Apabila medan dalam kunci utama bersama dipadamkan, jika kunci utama yang terdiri daripada medan yang tinggal masih memenuhi prinsip keunikan, maka kunci utama bersama adalah salah. Ini adalah prinsip meminimumkan.
Tetapkan kekangan kunci utama semasa membuat jadual
Tetapkan kekangan kunci utama semasa membuat jadual data, sama ada untuk jadual Tetapkan kunci utama untuk medan dalam jadual, atau tetapkan kunci utama bersama untuk berbilang medan dalam jadual. Tetapi tidak kira kaedah yang digunakan, hanya terdapat satu kunci utama dalam jadual. Berikut menerangkan cara untuk menetapkan kunci utama satu medan dan kunci utama gabungan berbilang medan.
1) Tetapkan kunci utama medan tunggal
Dalam penyataan CREATE TABLE, nyatakan kunci utama melalui kata kunci PRIMARY KEY.
Nyatakan kunci utama semasa mentakrifkan medan Format sintaks adalah seperti berikut:
<字段名> <数据类型> PRIMARY KEY [默认值]
Contoh 1
Buat jadual data tb_emp3 dalam pangkalan data test_db, yang mana kunci utama ialah id, SQL Penyataan dan keputusan yang dijalankan adalah seperti berikut.
mysql> CREATE TABLE tb_emp3 -> ( -> id INT(11) PRIMARY KEY, -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp3; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(25) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.14 sec)
Atau tentukan kunci utama selepas mentakrifkan semua medan Format sintaks adalah seperti berikut:
[CONSTRAINT <约束名>] PRIMARY KEY [字段名]
Contoh 2
Buat jadual data tb_emp4 dalam pangkalan data test_db, Kunci utamanya ialah id, dan penyata SQL serta keputusan yang dijalankan adalah seperti berikut.
mysql> CREATE TABLE tb_emp4 -> ( -> id INT(11), -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT, -> PRIMARY KEY(id) -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp4; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(25) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.14 sec)
2) Tetapkan kunci utama bersama semasa mencipta jadual
Kunci primer bersama yang dipanggil bermakna kunci utama terdiri daripada berbilang medan dalam sebuah meja.
Contohnya, semasa menyediakan jadual data pemilihan kursus pelajar, patutkah anda menggunakan nombor pelajar sebagai kunci utama atau nombor kursus sebagai kunci utama? Jika nombor pelajar digunakan sebagai kunci utama, maka pelajar hanya boleh memilih satu kursus. Jika nombor kursus digunakan sebagai kunci utama, maka hanya seorang pelajar boleh memilih kursus. Jelas sekali, kedua-dua situasi ini tidak realistik.
Malah, apabila mereka bentuk jadual pemilihan kursus pelajar, hadnya ialah pelajar hanya boleh memilih kursus yang sama sekali sahaja. Oleh itu, nombor pelajar dan nombor kursus boleh disatukan sebagai kunci utama, yang merupakan kunci primer bersama.
Kunci primer terdiri daripada berbilang medan Format sintaks adalah seperti berikut:
PRIMARY KEY [字段1,字段2,…,字段n]
Nota: Apabila kunci utama terdiri daripada berbilang medan, kekangan kunci primer tidak boleh diisytiharkan. terus selepas nama medan.
Contoh 3
Buat jadual data tb_emp5 Andaikan bahawa tiada id kunci utama dalam jadual untuk mengenal pasti pekerja secara unik, anda boleh menggabungkan nama dan deptId sebagai kunci utama . Pernyataan SQL dan keputusan berjalan adalah seperti berikut.
mysql> CREATE TABLE tb_emp5 -> ( -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT, -> PRIMARY KEY(name,deptId) -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp5; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | name | varchar(25) | NO | PRI | NULL | | | deptId | int(11) | NO | PRI | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 3 rows in set (0.14 sec)
Tambahkan kekangan kunci utama apabila mengubah suai jadual
Kekangan kunci utama boleh dibuat bukan sahaja semasa mencipta jadual, tetapi juga apabila mengubah suai jadual ditambah apabila. Walau bagaimanapun, perlu diingatkan bahawa nilai nol tidak dibenarkan dalam medan yang ditetapkan sebagai kekangan utama utama.
Format sintaks untuk menambah kekangan kunci utama apabila mengubah suai jadual data adalah seperti berikut:
ALTER TABLE <数据表名> ADD PRIMARY KEY(<字段名>);
Lihat struktur jadual jadual data tb_emp2 Penyataan SQL dan hasil yang dijalankan adalah seperti mengikuti.
mysql> DESC tb_emp2; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | | NULL | | | name | varchar(30) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.14 sec)
Contoh 4
Ubah suai jadual data tb_emp2 dan tetapkan id medan sebagai kunci utama Penyataan SQL dan hasil yang dijalankan adalah seperti berikut.
mysql> ALTER TABLE tb_emp2 -> ADD PRIMARY KEY(id); Query OK, 0 rows affected (0.94 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC tb_emp2; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(30) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.12 sec)
Biasanya, apabila anda ingin menetapkan kekangan kunci utama medan dalam jadual apabila mengubah suai jadual, anda mesti memastikan bahawa nilai dalam medan yang ditetapkan sebagai kekangan kunci utama tidak boleh mempunyai pendua, dan pastikan bahawa ia adalah benar dan salah. Jika tidak, kekangan kunci utama tidak boleh ditetapkan.
Indeks (Indeks) MySQL
Indeks ialah struktur pangkalan data khas, yang terdiri daripada satu atau lebih lajur dalam jadual data Ia boleh digunakan untuk menanya dengan pantas lajur tertentu dalam jadual data.
Dengan indeks, anda tidak perlu membaca semua maklumat dalam rekod semasa menanyakan data, tetapi hanya menanya lajur indeks. Jika tidak, sistem pangkalan data akan membaca semua maklumat setiap rekod untuk dipadankan.
Indeks boleh dibandingkan dengan urutan fonetik Kamus Xinhua. Sebagai contoh, jika anda ingin mencari perkataan "ku", jika anda tidak menggunakan urutan fonetik, anda perlu mencarinya halaman demi halaman dalam 400 halaman kamus. Walau bagaimanapun, jika anda mengekstrak pinyin untuk membentuk urutan fonetik, anda hanya perlu mencarinya terus daripada jadual fonetik lebih daripada 10 halaman. Ini boleh menjimatkan banyak masa.
Kebaikan dan Kelemahan Pengindeksan
Pengindeksan mempunyai kelebihan yang jelas dan keburukan yang tidak dapat dielakkan.
Kelebihan
Kelebihan indeks adalah seperti berikut:
Dengan mencipta indeks unik, keunikan setiap baris data dalam jadual pangkalan data boleh dijamin.
Boleh menetapkan indeks untuk semua jenis lajur MySQL.
boleh mempercepatkan pertanyaan data, yang merupakan sebab utama untuk menggunakan indeks.
boleh mempercepatkan sambungan antara jadual dari segi mencapai integriti rujukan data.
Apabila menggunakan klausa pengumpulan dan pengisihan untuk pertanyaan data, masa pengumpulan dan pengisihan dalam pertanyaan juga boleh dikurangkan dengan ketara
Kelemahan
Terdapat juga banyak keburukan untuk menambah indeks, terutamanya seperti berikut:
Mencipta dan menyelenggara kumpulan indeks mengambil masa, dan masa yang dibelanjakan meningkat apabila jumlah data meningkat.
Indeks perlu menduduki ruang cakera Selain ruang data yang diduduki oleh jadual data, setiap indeks juga menduduki sejumlah ruang fizikal. Jika anda mempunyai bilangan indeks yang banyak, fail indeks mungkin mencapai saiz fail maksimumnya lebih cepat daripada fail data.
Apabila menambah, memadam dan mengubah suai data dalam jadual, indeks mesti dikekalkan secara dinamik, yang mengurangkan kelajuan penyelenggaraan data.
Apabila menggunakan indeks, anda perlu mempertimbangkan kebaikan dan keburukan indeks.
Indeks boleh meningkatkan kelajuan pertanyaan, tetapi akan menjejaskan kelajuan memasukkan rekod. Kerana apabila memasukkan rekod ke dalam jadual yang diindeks, sistem pangkalan data akan menyusun mengikut indeks, yang mengurangkan kelajuan memasukkan rekod Kesan kelajuan akan menjadi lebih jelas apabila memasukkan sejumlah besar rekod. Dalam kes ini, cara terbaik ialah memadam indeks dalam jadual dahulu, kemudian masukkan data, dan kemudian buat indeks selepas sisipan selesai.
[Cadangan berkaitan: tutorial video mysql]
Atas ialah kandungan terperinci Adakah kunci utama dalam mysql indeks?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Bagaimana untuk memantau prestasi MySQL dengan berkesan? Gunakan alat seperti mysqladmin, showglobalstatus, perconamonitoring dan pengurusan (PMM), dan mysql enterprisemonitor. 1. Gunakan mysqladmin untuk melihat bilangan sambungan. 2. Gunakan showglobalstatus untuk melihat nombor pertanyaan. 3.Pmm menyediakan data prestasi terperinci dan antara muka grafik. 4.MySqLenterPrisemonitor menyediakan fungsi pemantauan yang kaya dan mekanisme penggera.

Perbezaan antara MySQL dan SQLServer adalah: 1) MySQL adalah sumber terbuka dan sesuai untuk sistem web dan tertanam, 2) SQLServer adalah produk komersil Microsoft dan sesuai untuk aplikasi peringkat perusahaan. Terdapat perbezaan yang signifikan antara kedua -dua enjin penyimpanan, pengoptimuman prestasi dan senario aplikasi. Apabila memilih, anda perlu mempertimbangkan saiz projek dan skalabiliti masa depan.

Dalam senario aplikasi peringkat perusahaan yang memerlukan ketersediaan yang tinggi, keselamatan maju dan integrasi yang baik, SQLServer harus dipilih bukannya MySQL. 1) SQLServer menyediakan ciri peringkat perusahaan seperti ketersediaan tinggi dan keselamatan maju. 2) Ia bersepadu dengan ekosistem Microsoft seperti VisualStudio dan PowerBI. 3) SQLServer melakukan pengoptimuman prestasi yang sangat baik dan menyokong jadual yang dioptimumkan memori dan indeks penyimpanan lajur.

Mysqlmanagescharactersetsandcollationsbyusingutf-8asthedefault, membolehkanConfigurationatdatabase, table, andcolumnlevels, andrequiringcarefulalignmenttoavoidmismatches.1) setdefaultcharactandcollationforadatabase.2) configurecharact

Pencetus MySQL adalah prosedur yang disimpan secara automatik yang dikaitkan dengan jadual yang digunakan untuk melakukan satu siri operasi apabila operasi data tertentu dilakukan. 1) Definisi dan fungsi pencetus: Digunakan untuk pengesahan data, pembalakan, dan lain-lain. 2) Prinsip kerja: Ia dibahagikan kepada sebelum dan selepas, dan menyokong pencetus peringkat baris. 3) Contoh Penggunaan: Boleh digunakan untuk merakam perubahan gaji atau mengemas kini inventori. 4) Kemahiran Debugging: Gunakan perintah showtriggers dan showcreateTrigger. 5) Pengoptimuman Prestasi: Elakkan operasi kompleks, menggunakan indeks, dan menguruskan urus niaga.

Langkah -langkah untuk membuat dan mengurus akaun pengguna di MySQL adalah seperti berikut: 1. Buat pengguna: Gunakan createuser'newuser '@' localhost'identifiedby'password '; 2. Menetapkan Kebenaran: Gunakan Grantselect, Insert, UpdateOnmydatabase.to'newuser'@'localhost '; 3. Betulkan Ralat Kebenaran: Gunakan RevokeAllPrivileSeonMydatabase.from'newuser'@'localhost '; kemudian menetapkan semula kebenaran; 4. Kebenaran Pengoptimuman: Gunakan Showgra

MySQL sesuai untuk pembangunan pesat dan aplikasi kecil dan sederhana, sementara Oracle sesuai untuk perusahaan besar dan keperluan ketersediaan yang tinggi. 1) MySQL adalah sumber terbuka dan mudah digunakan, sesuai untuk aplikasi web dan perusahaan kecil dan sederhana. 2) Oracle berkuasa dan sesuai untuk perusahaan besar dan agensi kerajaan. 3) MySQL menyokong pelbagai enjin penyimpanan, dan Oracle menyediakan fungsi peringkat perusahaan yang kaya.

Kelemahan MySQL berbanding dengan pangkalan data relasi lain termasuk: 1. Isu Prestasi: Anda mungkin menghadapi kesesakan apabila memproses data berskala besar, dan PostgreSQL melakukan lebih baik dalam pertanyaan kompleks dan pemprosesan data besar. 2. Skalabiliti: Keupayaan skala mendatar tidak sebaik Google Spanner dan Amazon Aurora. 3. Batasan Fungsian: Tidak sebaik PostgreSQL dan Oracle dalam Fungsi Lanjutan, beberapa fungsi memerlukan lebih banyak kod dan penyelenggaraan tersuai.


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

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

Artikel Panas

Alat panas

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Pelayar Peperiksaan Selamat
Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

SublimeText3 versi Inggeris
Disyorkan: Versi Win, menyokong gesaan kod!