


Bagaimana untuk menulis kekangan kunci asing semasa membuat jadual dalam MySQL
Mencipta kekangan kunci asing jadual dalam MySQL memastikan integriti rujukan. Langkah-langkahnya adalah seperti berikut: Cipta dua jadual dan tentukan kunci utama. Tambahkan kekangan KUNCI ASING pada jadual anak, merujuk kunci utama jadual induk. Secara pilihan, nyatakan tindakan rujukan (seperti pemadaman bertingkat atau kemas kini terhad).
Buat kekangan kunci asing jadual dalam MySQL
Apabila kekangan kunci asing diwujudkan antara dua jadual, integriti rujukan di antara mereka boleh dipastikan. Langkah berikut memperkenalkan cara mencipta kekangan kunci asing jadual dalam MySQL:
Langkah 1: Buat dua jadual
Buat dua jadual di mana kita ingin mewujudkan kekangan kunci asing:
CREATE TABLE parent_table ( id INT NOT NULL, name VARCHAR(255) NOT NULL, PRIMARY KEY (id) ); CREATE TABLE child_table ( id INT NOT NULL, parent_id INT NOT NULL, value VARCHAR(255) NOT NULL, PRIMARY KEY (id), FOREIGN KEY (parent_id) REFERENCES parent_table(id) );
Langkah 2 : Tambah kekangan kunci asing dalam jadual anak
Dalam child_table
, gunakan kekangan FOREIGN KEY
untuk merujuk lajur parent_id
ke parent_table <code>id
lajur dalam : child_table
中,使用 FOREIGN KEY
约束将 parent_id
列引用到 parent_table
中的 id
列:
ALTER TABLE child_table ADD FOREIGN KEY (parent_id) REFERENCES parent_table(id);
第三步:指定引用操作(可选)
您可以使用 ON DELETE
和 ON UPDATE
子句指定在对父表进行删除或更新操作时对子表中受影响记录的行为:
ALTER TABLE child_table ADD FOREIGN KEY (parent_id) REFERENCES parent_table(id) ON DELETE CASCADE ON UPDATE RESTRICT;
在这段代码中:
-
ON DELETE CASCADE
:当从parent_table
中删除记录时,将自动从child_table
中级联删除相关记录。 -
ON UPDATE RESTRICT
:当parent_table
中的记录被更新时,将阻止对child_table
rrreee
Anda boleh menggunakan ON DELETE
dan ON UPDATE
klausa menentukan kelakuan untuk rekod yang terjejas dalam jadual anak apabila operasi pemadaman atau kemas kini dilakukan pada jadual induk:
- Dalam kod ini:
ON DELETE CASCADE: Apabila rekod dipadamkan daripada parent_table
, rekod yang berkaitan akan dipadamkan secara automatik daripadachild_table
dalam lata.PADA HAD KEMASKINI: Apabila rekod dalam parent_table
dikemas kini, sebarang kemas kini kepada rekod yang terjejas dalamchild_table
akan disekat.
Atas ialah kandungan terperinci Bagaimana untuk menulis kekangan kunci asing semasa membuat jadual dalam MySQL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

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

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apabila berurusan dengan jadual besar, prestasi MySQL dan penyelenggaraan menghadapi cabaran, dan perlu bermula dari reka bentuk struktur, pengoptimuman indeks, strategi sub-meja jadual, dan sebagainya. 1. Gunakan indeks overlay untuk meningkatkan kecekapan pertanyaan; kerap menganalisis log pertanyaan perlahan dan memadam indeks tidak sah. 2. 3. Pertimbangkan pembacaan dan penulisan pemisahan dan pemisahan perpustakaan: Baca dan menulis pemisahan mengurangkan tekanan pada perpustakaan utama. Pemisahan perpustakaan dan pemisahan jadual sesuai untuk senario dengan sejumlah besar data. Adalah disyorkan untuk menggunakan middleware dan menilai masalah urus niaga dan masalah pertanyaan silang. Perancangan awal dan pengoptimuman berterusan adalah kunci.

MySQL menyokong kekangan cek untuk memaksa integriti domain, berkesan dari versi 8.0.16; 1. Tambah kekangan apabila membuat jadual: Gunakan createtable untuk menentukan syarat semak, seperti umur ≥18, gaji> 0, nilai had jabatan; 2. Ubah suai jadual untuk menambah kekangan: Gunakan altertableaddConstraint untuk mengehadkan nilai medan, seperti nama tidak kosong; 3. Menggunakan syarat-syarat yang kompleks: menyokong logik dan ekspresi multi-lajur, seperti tarikh akhir ≥ multart status dan status siap mesti mempunyai tarikh akhir; 4. Padam Kekangan: Gunakan alterTableDRopConstraint untuk menentukan nama untuk memadam; 5. Nota: Mysql8.0.16, InnoDB atau Myisam perlu disebutkan

Useamany-to-manyrelationshipwithajunctionTableTolinkitemsandtagsviathreetables: item, tags, anditem_tags.2.WhenaddingTags, checkorexistingtagsinthetagstable, InsertIfnerary, thencreatemappingsinitem_TagsusterShanTaStranitem_TagsingTrans

Kaedah teras untuk merealisasikan pengesan hubungan darah MySQL termasuk: 1. Gunakan binlog untuk merakam sumber perubahan data, membolehkan dan menganalisis binlog, dan mengesan tindakan perniagaan tertentu dalam kombinasi dengan konteks lapisan aplikasi; 2. Suntikan tag ikatan darah ke dalam proses ETL, dan merekodkan hubungan pemetaan antara sumber dan sasaran apabila menyegerakkan alat; 3. Tambah komen dan tag metadata ke data, terangkan sumber medan apabila membina jadual, dan sambungkan ke sistem pengurusan metadata untuk membentuk peta visual; 4. Perhatikan konsistensi utama utama, elakkan kebergantungan yang berlebihan pada analisis SQL, perubahan model data kawalan versi, dan kerap memeriksa data hubungan darah untuk memastikan penjejakan hubungan darah yang tepat dan boleh dipercayai.

Semak sama ada perkhidmatan MySQL sedang berjalan, gunakan sudosystemctlstatusmysql untuk mengesahkan dan memulakan; 2. Pastikan alamat pengikat ditetapkan kepada 0.0.0.0 untuk membolehkan sambungan jauh dan mulakan semula perkhidmatan; 3. Sahkan sama ada pelabuhan 3306 dibuka, periksa dan konfigurasikan peraturan firewall untuk membenarkan pelabuhan; 4. Untuk ralat "Accessdenied", anda perlu menyemak nama pengguna, kata laluan dan nama hos, dan kemudian log masuk ke MySQL dan menanyakan jadual MySQL.user untuk mengesahkan kebenaran. Jika perlu, buat atau kemas kini pengguna dan membenarkannya, seperti menggunakan 'your_user'@'%'; 5. Sekiranya pengesahan hilang kerana caching_sha2_password

Untuk memaparkan semua pangkalan data dalam MySQL, anda perlu menggunakan perintah ShowDatabases; 1. Selepas log masuk ke pelayan MySQL, anda boleh melaksanakan showdatabases; perintah untuk menyenaraikan semua pangkalan data bahawa pengguna semasa mempunyai kebenaran untuk mengakses; 2. Pangkalan data sistem seperti Maklumat_Schema, MySQL, Performance_Schema dan SYS wujud secara lalai, tetapi pengguna yang mempunyai kebenaran yang tidak mencukupi mungkin tidak dapat melihatnya; 3. Anda juga boleh menanyakan dan menapis pangkalan data melalui selectschema_namefrominformation_schema.schemata; Sebagai contoh, tidak termasuk pangkalan data sistem untuk hanya memaparkan pangkalan data yang dibuat oleh pengguna; Pastikan untuk menggunakan

Deleteremovesspecificorallrows, keepstableStructure, membolehkan rollrackandtriggers, anddoesnotresetauto-increment; 2.truncatequicklyremovesallrows, resetsauto-increment, tidak boleh dibebaskan

Checkcompatebilitywithos, aplikasi, dan features; 2.backupalldata, configs, andlogs; 3.chooseupgrademethod (packageManager, mysqlinstaller, ormanual); 4.Runpost-upgradeChecksandTests;
