Rumah  >  Artikel  >  pangkalan data  >  Adakah kunci utama dalam mysql indeks?

Adakah kunci utama dalam mysql indeks?

青灯夜游
青灯夜游asal
2021-12-27 17:40:286275semak imbas

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.

Adakah kunci utama dalam mysql indeks?

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!

Kenyataan:
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