Apakah konsep kekangan dan indeks MySQL
1. Peraturan reka bentuk pangkalan data hubungan
Ikuti model ER dan tiga bentuk biasa
Entiti E mewakili entiti dan sepadan dengan jadual dalam pangkalan data
Perhubungan R bermaksud perhubungan
Tiga bentuk biasa:
1 Lajur tidak boleh dipisahkan
2 , pengecam unik
3. Kunci utama rujukan perhubungan
penjelmaan konkrit
masukkan data ke dalam jadual, dan kemudian letakkan jadual ke dalam perpustakaan .
Boleh terdapat berbilang jadual dalam pangkalan data dan setiap jadual mempunyai nama untuk mengenal pasti dirinya. Nama jadual adalah unik.
Jadual mempunyai beberapa ciri yang menentukan cara data disimpan dalam jadual, serupa dengan reka bentuk "kelas" dalam java dan python.
Jadual terdiri daripada lajur, yang juga kami panggil medan. Reka bentuk jadual data sebenarnya adalah reka bentuk dan penerangan bagi maksud setiap medan. Apabila membuat jadual data, anda perlu menentukan jenis data untuk setiap medan, menentukan panjang data dan penamaannya. Setiap medan adalah serupa dengan "atribut contoh" dalam java atau python.
Data dalam jadual disimpan dalam baris dan satu baris ialah rekod. Setiap baris adalah serupa dengan "objek" dalam java atau python.
2. Konsep integriti data, kekangan dan indeks
1 point bertujuan untuk menghalang kewujudan data yang tidak mematuhi peraturan semantik dalam pangkalan data, sambil mengelakkan operasi tidak sah atau mesej ralat yang disebabkan oleh input dan output maklumat yang salah
Data Integriti harus dipertimbangkan daripada yang berikut empat aspek:
Integriti Entiti: Contohnya, tidak boleh ada dua rekod yang sama dan tidak boleh dibezakan dalam jadual yang sama
Integriti Domain: Contohnya : lingkungan umur 0-120, julat jantina "lelaki/perempuan"
Integriti Integriti Rujukan): Contohnya: jabatan di mana pekerja berada, jabatan ini mesti ditemui di jabatan jadual
Integriti yang ditetapkan pengguna: Contohnya: nama pengguna adalah unik dan kata laluan tidak boleh Jika kosong, gaji pengurus jabatan ini tidak melebihi 5 kali ganda purata gaji pekerja di jabatan ini sebagai objek pangkalan data. Mereka mempunyai nama dan corak yang berkaitan, dan tiada kekangan tambahan untuk menetapkan ruang
3 struktur pangkalan data fizikal yang berasingan yang disimpan pada halaman data Ia adalah koleksi dan set yang sepadan dengan satu atau beberapa nilai lajur dalam jadual jadual (serupa dengan halaman indeks direktori Kamus Xinhua Kewujudan indeks akan meningkatkan ruang penyimpanan pangkalan data dan juga meningkatkan overhed masa untuk memasukkan dan mengubah suai data (kerana Apabila memasukkan dan mengubah suai data, indeks juga akan). berubah dengan sewajarnya), tetapi ia boleh meningkatkan kelajuan pertanyaan dengan ketara Oleh itu, indeks harus dibuat pada lajur utama atau lajur lain yang kerap ditanya, diisih dan dicari mengikut julat, dan untuk pertanyaan yang sangat pantas pada lajur yang jarang digunakan dan dirujuk, lajur yang sangat kerap diubah suai dan lajur dengan sedikit nilai (seperti jantina sahaja lelaki dan perempuan). Indeks akan dibuat secara automatik pada lajur kunci utama, kunci unik dan kunci asing Jika lajur lain perlu diindeks, lajur tersebut perlu dibuat secara manual
②Kunci utama akan dipadamkan dan indeks yang sepadan akan. juga dipadamkan
③Padam Kaedah kunci unik dicapai dengan memadamkan indeks yang sepadan
④ Padamkan kunci asing Indeks pada lajur kunci asing masih ada itu, anda perlu memadamkan indeks secara berasingan
3. Aplikasi Kekangan
1 Lihat kekangan dan indeks jadual
#查看某个表的约束 SELECT * FROM information_schema.table_constraints WHERE table_name = '表名称'; 或 SHOW CREATE TABLE 表名; #查看某个表的索引 SHOW INDEX FROM 表名称;
#单个字段设置主键 create table t_user( id int primary key, username varchar(20), password varchar(20) ); create table t_user( id int, username varchar(20), password varchar(20), primary key(id) ); #多个字段设置联合主键 drop table t_user; create table t_user( id int, username varchar(20), password varchar(20), primary key(id,username) ); #了解 #在建表后指定主键约束 alter table 表名称 add primary key (主键字段列表); #删除主键约束 alter table 表名称 drop primary key;
- 4. Dalam kunci primer bersama, setiap medan yang membentuk kunci utama bukan- kosong dan boleh diulang secara individu, tetapi tidak boleh diulang pada masa yang sama
- 5 Mencipta kunci utama akan membuat indeks yang sepadan secara automatik dan memadamkan indeks yang sepadan dengan kunci utama akan juga dipadamkan.
- 3. Kekangan kenaikan automatik: auto_increeCiri kekangan autoincree:
create table t_user( id int primary key auto_increment, username varchar(20), password varchar(20) ); #建表后指定自增长列 alter table [数据库.]表名 modify 自增字段名 数据类型 auto_increment; #删除自增约束 alter table 表名 modify 自增字段名 数据类型;
Salin selepas log masuk - Memerlukan hanya satu kunci utama dalam jadual daripada Medan jenis kenaikan automatik, medan ini mestilah integer dan tidak boleh kosong. Biasanya kekangan utama hanya ditetapkan pada kunci utama, seperti kekangan kunci utama, kekangan kunci unik, kekangan kunci asing
2、设置为自增的字段,从1开始自增;每次添加数据,都会在该字段最大值的基础上+1
3、使字段自增的方式:
如果是空或者0,则实际插入的将是自动增长后的值。
a> insert into t_user(username,password) values(‘admin’,‘123456’);
b> insert into t_user values(null,‘root’,‘123456’); (推荐使用)
c> insert into t_user values(0,‘root’,‘123456’);
4、唯一键约束:unique key
create table t_user( id int primary key auto_increment, username varchar(20) unique key, password varchar(20) unique key ); create table t_user( id int primary key auto_increment, username varchar(20), password varchar(20), unique key(username,password) ); #在建表后增加唯一键约束 alter table 表名称 add 【constraint 约束名】 unique key (字段名列表); #如果没有指定约束名,(字段名列表)中只有一个字段的,默认是该字段名,如果是多个字段的默认是字段名列表的第1个字段名。也可以通过show index from 表名;来查看 #删除唯一键约束 ALTER TABLE 表名称 DROP INDEX 唯一性约束名; #注意:如果忘记名称,可以通过“show index from 表名称;”查看
Salin selepas log masuk唯一键约束的特点:
1、设置唯一键约束的字段值唯一,但是可以为null
2、一张表可以设置多个唯一键约束,也可以设置联合唯一键,即多个字段设置一个唯一约束,但是不能使用"unique key"写在字段后设置,必须写在所有字段后,使用"unique key(字段,字段)"
3、联合唯一键要求组成唯一约束的字段可以单独重复,不能同时重复
4、 MySQL会给唯一约束的列上默认创建一个唯一索引。
5、删除唯一键只能通过删除对应索引的方式删除,删除时需要指定唯一键索引名
5、非空约束:not null
create table t_user( id int primary key auto_increment, username varchar(20) unique key not null, password varchar(20) ); #在建表后指定某个字段非空 ALTER TABLE 表名称 MODIFY 字段名 数据类型 NOT NULL 【default 默认值】; #如果该字段原来设置了默认值约束,要跟着一起再写一遍,否则默认值约束会丢失 #取消某个字段非空 ALTER TABLE 表名称 MODIFY 字段名 数据类型 【default 默认值】; #如果该字段原来设置了默认值约束,要跟着一起再写一遍,否则默认值约束会丢失
Salin selepas log masuk非空约束的特点:
设置为非空约束的字段的值不能为null
6、默认值约束:default
create table t_user( id int primary key auto_increment, username varchar(20) unique key not null, password varchar(20), gender char not null default '男' );
Salin selepas log masuk添加数据时使用默认值的方式:
不为该字段赋值或使用关键字default
insert into t_user(username,password) values(‘root’,‘123’);
insert into t_user values(null,‘admin123’,‘123’,default);
insert into t_user values(null,‘admin’,‘123’,null); //此方式不可以,会为该字段赋值为null
7、外键约束:foreign key
表关系:
1、一对一
2、多对一,在多的一方引用一的主键
student(sid,sname,age,sex,cid)–clazz(cid,cname,location)
3、一对多,在多的一方引用一的主键
clazz(cid,cname,location)–student(sid,sname,age,sex,cid)
4、多对多
user(uid,username,password)
order(oid,create_time,total_count,total_amount,status,user_id)
order_goods(id,oid,gid)
goods(gid,gname,price,sales,stock)
create table t_dept( id int primary key auto_increment, name varchar(20) ); create table t_emp( id int primary key auto_increment, name varchar(20), age int, gender char, dept_id int, foreign key(dept_id) references t_dept(id) #外键只能在所有字段列表后面单独指定 ); #在建表后指定外键约束 alter table 从表名称 add 【constraint 外键约束名】 foreign key (从表字段名) references 主表名(主表被参照字段名) 【on update xx】[on delete xx]; #删除外键约束 ALTER TABLE 表名称 DROP FOREIGN KEY 外键约束名; #查看某个表的约束名 SELECT * FROM information_schema.table_constraints WHERE table_name = '表名称'; 或 SHOW CREATE TABLE 表名; #删除外键约束不会删除对应的索引,如果需要删除索引,需要用ALTER TABLE 表名称 DROP INDEX 索引名; #查看索引名 show index from 表名称;
Salin selepas log masuk(1)外键特点
外键约束是保证一个或两个表之间的参照完整性,外键是构建于一个表的两个字段或是两个表的两个字段之间的参照关系。
在创建外键约束时,如果不给外键约束名称,默认名不是列名,而是自动产生一个外键名(例如 student_ibfk_1;),也可以指定外键约束名。
当创建外键约束时,系统默认会在所在的列上建立对应的普通索引。但是索引名是列名,不是外键的约束名。
删除外键时,关于外键列上的普通索引需要单独删除。
(2)要求
在从表上建立外键,而且主表要先存在。
一个表可以建立多个外键约束
从表的外键列,在主表中引用的只能是键列(主键,唯一键,外键),推荐引用主表的主键。
从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样
(3)约束关系:约束是针对双方的
添加了外键约束后,主表的修改和删除数据受约束
添加了外键约束后,从表的添加和修改数据受约束
在从表上建立外键,要求主表必须存在
删除主表时,要求从表先删除,或将从表中外键引用该主表的关系先删除
(4)5个约束等级
Cascade方式:在父表上update/delete记录时,同步update/delete掉子表的匹配记录
Set null方式:在父表上update/delete记录时,将子表上匹配记录的列设为null,但是要注意子表的外键列不能为not null
No action方式:如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作
Restrict方式:同no action, 都是立即检查外键约束
Set default方式(在可视化工具SQLyog中可能显示空白):父表有变更时,子表将外键列设置成一个默认的值,但Innodb不能识别
如果没有指定等级,就相当于Restrict方式
8、检查约束:check
检查约束,mysql暂不支持
create table stu( sid int primary key, sname varchar(20), gender char check ('男'or'女') ); insert into stu values(1,'张三','男'); insert into stu values(2,'李四','妖'); 使用枚举类型解决如上问题: create table stu( sid int primary key, sname varchar(20), gender enum ('男','女') );
Salin selepas log masukAtas ialah kandungan terperinci Apakah konsep kekangan dan indeks MySQL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

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)

Topik panas











Laravel adalah rangka kerja PHP untuk membina aplikasi web yang mudah. Ia menyediakan pelbagai ciri yang kuat termasuk: Pemasangan: Pasang Laravel CLI secara global dengan komposer dan buat aplikasi dalam direktori projek. Routing: Tentukan hubungan antara URL dan pengendali dalam laluan/web.php. Lihat: Buat pandangan dalam sumber/pandangan untuk menjadikan antara muka aplikasi. Integrasi Pangkalan Data: Menyediakan integrasi keluar-of-the-box dengan pangkalan data seperti MySQL dan menggunakan penghijrahan untuk membuat dan mengubah suai jadual. Model dan Pengawal: Model mewakili entiti pangkalan data dan proses pengawal permintaan HTTP.

MySQL dan phpmyadmin adalah alat pengurusan pangkalan data yang kuat. 1) MySQL digunakan untuk membuat pangkalan data dan jadual, dan untuk melaksanakan pertanyaan DML dan SQL. 2) Phpmyadmin menyediakan antara muka intuitif untuk pengurusan pangkalan data, pengurusan struktur meja, operasi data dan pengurusan kebenaran pengguna.

Berbanding dengan bahasa pengaturcaraan lain, MySQL digunakan terutamanya untuk menyimpan dan mengurus data, manakala bahasa lain seperti Python, Java, dan C digunakan untuk pemprosesan logik dan pembangunan aplikasi. MySQL terkenal dengan prestasi tinggi, skalabilitas dan sokongan silang platform, sesuai untuk keperluan pengurusan data, sementara bahasa lain mempunyai kelebihan dalam bidang masing-masing seperti analisis data, aplikasi perusahaan, dan pengaturcaraan sistem.

Saya menghadapi masalah yang rumit ketika membangunkan aplikasi kecil: keperluan untuk mengintegrasikan perpustakaan operasi pangkalan data ringan dengan cepat. Selepas mencuba beberapa perpustakaan, saya mendapati bahawa mereka mempunyai terlalu banyak fungsi atau tidak serasi. Akhirnya, saya dapati Minii/DB, versi mudah berdasarkan YII2 yang menyelesaikan masalah saya dengan sempurna.

Ringkasan Artikel: Artikel ini menyediakan arahan langkah demi langkah terperinci untuk membimbing pembaca tentang cara memasang rangka kerja Laravel dengan mudah. Laravel adalah rangka kerja PHP yang kuat yang mempercepat proses pembangunan aplikasi web. Tutorial ini merangkumi proses pemasangan dari keperluan sistem untuk mengkonfigurasi pangkalan data dan menyediakan penghalaan. Dengan mengikuti langkah -langkah ini, pembaca dapat dengan cepat dan cekap meletakkan asas yang kukuh untuk projek Laravel mereka.

MySQL dengan cekap menguruskan data berstruktur melalui struktur jadual dan pertanyaan SQL, dan melaksanakan hubungan antara meja melalui kunci asing. 1. Tentukan format data dan taip apabila membuat jadual. 2. Gunakan kunci asing untuk mewujudkan hubungan antara jadual. 3. Meningkatkan prestasi melalui pengindeksan dan pengoptimuman pertanyaan. 4. Secara kerap sandaran dan memantau pangkalan data untuk memastikan pengoptimuman keselamatan data dan prestasi.

Apabila membangunkan laman web e-dagang menggunakan Thelia, saya menghadapi masalah yang rumit: mod MySQL tidak ditetapkan dengan betul, menyebabkan beberapa ciri tidak berfungsi dengan baik. Selepas beberapa penjelajahan, saya dapati modul yang dipanggil TheLiamySqlModesChecker, yang dapat secara automatik membetulkan corak MySQL yang diperlukan oleh Thelia, menyelesaikan masalah saya sepenuhnya.

MySQL adalah sistem pengurusan pangkalan data sumber terbuka yang digunakan secara meluas dalam pembangunan web. Ciri -ciri utamanya termasuk: 1. Menyokong pelbagai enjin penyimpanan, seperti InnoDB dan Myisam, sesuai untuk senario yang berbeza; 2. Menyediakan fungsi replikasi master-hamba untuk memudahkan pengimbangan beban dan sandaran data; 3. Meningkatkan kecekapan pertanyaan melalui pengoptimuman pertanyaan dan penggunaan indeks.
